diff --git a/specification/wasm-1.0/B-soundness.spectec b/specification/wasm-1.0/B-soundness.spectec index e89a326db9..87867fb58a 100644 --- a/specification/wasm-1.0/B-soundness.spectec +++ b/specification/wasm-1.0/B-soundness.spectec @@ -129,13 +129,13 @@ rule Globalinst_ok: -- Val_ok: |- val : t rule Meminst_ok: - s |- {TYPE `[n..m], BYTES b*} : `[n..m] - -- Memtype_ok: |- `[n..m] : OK + s |- {TYPE `[n..m?], BYTES b*} : `[n..m?] + -- Memtype_ok: |- `[n..m?] : OK -- if |b*| = $(n * $($(64 * $Ki))) rule Tableinst_ok: - s |- {TYPE `[n..m] , REFS (fa?)*} : `[n..m] - -- Tabletype_ok: |- `[n..m] : OK + s |- {TYPE `[n..m?] , REFS (fa?)*} : `[n..m?] + -- Tabletype_ok: |- `[n..m?] : OK -- ((Externaddr_ok: s |- FUNC fa : FUNC ft)?)* -- if |(fa?)*| = n @@ -204,12 +204,12 @@ rule Extend_globalinst: -- if mut = MUT \/ val = val' rule Extend_meminst: - {TYPE `[n..m], BYTES b*} `<= {TYPE `[n'..m], BYTES b'*} + {TYPE `[n..m?], BYTES b*} `<= {TYPE `[n'..m?], BYTES b'*} -- if n <= n' -- if |b*| <= |b'*| rule Extend_tableinst: - {TYPE `[n..m], REFS ref*} `<= {TYPE `[n'..m], REFS ref'*} + {TYPE `[n..m?], REFS ref*} `<= {TYPE `[n'..m?], REFS ref'*} -- if n <= n' -- if |ref*| <= |ref'*| @@ -240,6 +240,6 @@ rule State_ok: -- Frame_ok: s |- f : C rule Config_ok: - |- s; f; instr* : t? + |- s; f; admininstr* : t? -- State_ok: |- s; f : C -- Expr_ok2: s; C |- admininstr* : t? diff --git a/specification/wasm-2.0/8-reduction.spectec b/specification/wasm-2.0/8-reduction.spectec index 8ded912097..b928044089 100644 --- a/specification/wasm-2.0/8-reduction.spectec +++ b/specification/wasm-2.0/8-reduction.spectec @@ -2,9 +2,9 @@ ;; Configurations ;; -relation Step: config ~> config hint(show "E") hint(tabular) -relation Step_pure: admininstr* ~> admininstr* hint(show "E") hint(tabular) -relation Step_read: config ~> admininstr* hint(show "E") hint(tabular) +relation Step: config ~> config hint(show "E") hint(tabular) hint(mode %1 -> %2) hint(wfopt) +relation Step_pure: admininstr* ~> admininstr* hint(show "E") hint(tabular) hint(mode %1 -> %2) hint(wfopt) +relation Step_read: config ~> admininstr* hint(show "E") hint(tabular) hint(mode %1 -> %2) hint(wfopt) relation Steps: config ~>* config hint(show "E") hint(tabular) rule Step/pure: diff --git a/specification/wasm-2.0/9-module.spectec b/specification/wasm-2.0/9-module.spectec index e456fc0a17..69d3bbf6e2 100644 --- a/specification/wasm-2.0/9-module.spectec +++ b/specification/wasm-2.0/9-module.spectec @@ -158,7 +158,7 @@ def $runelem(ELEM reftype expr* (ACTIVE x instr*), i) = instr* (CONST I32 0) (CONST I32 n) (TABLE.INIT x i) (ELEM.DROP i) -- if n = |expr*| -def $rundata(data, idx) : instr* +def $rundata(data, idx) : instr* hint(partial) def $rundata(DATA byte* (PASSIVE), i) = eps def $rundata(DATA byte* (ACTIVE 0 instr*), i) = instr* (CONST I32 0) (CONST I32 n) (MEMORY.INIT i) (DATA.DROP i) diff --git a/specification/wasm-2.0/B-soundness.spectec b/specification/wasm-2.0/B-soundness.spectec index 4e8d403675..656b2d5768 100644 --- a/specification/wasm-2.0/B-soundness.spectec +++ b/specification/wasm-2.0/B-soundness.spectec @@ -107,7 +107,7 @@ rule Instrs_ok2/seq: -- Instrs_ok2: s; C |- admininstr_2* : t_2* -> t_3* rule Instrs_ok2/sub: - s; C |- instr* : t'_1* -> t'_2* + s; C |- admininstr* : t'_1* -> t'_2* -- Instrs_ok2: s; C |- admininstr* : t_1* -> t_2* -- Resulttype_sub: |- t'_1* <: t_1* -- Resulttype_sub: |- t_2* <: t'_2* @@ -161,13 +161,13 @@ rule Globalinst_ok: -- Val_ok: s |- val : t rule Meminst_ok: - s |- {TYPE `[n..m] PAGE, BYTES b*} : `[n..m] PAGE - -- Memtype_ok: |- `[n..m] PAGE : OK + s |- {TYPE `[n..m?] PAGE, BYTES b*} : `[n..m?] PAGE + -- Memtype_ok: |- `[n..m?] PAGE : OK -- if |b*| = $(n * $($(64 * $Ki))) rule Tableinst_ok: - s |- {TYPE `[n..m] rt , REFS ref*} : `[n..m] rt - -- Tabletype_ok: |- `[n..m] rt : OK + s |- {TYPE `[n..m?] rt , REFS ref*} : `[n..m?] rt + -- Tabletype_ok: |- `[n..m?] rt : OK -- (Ref_ok : s |- ref : rt)* -- if |ref*| = n @@ -254,12 +254,12 @@ rule Extend_globalinst: -- if mut = MUT \/ val = val' rule Extend_meminst: - {TYPE `[n..m] PAGE, BYTES b*} `<= {TYPE `[n'..m] PAGE, BYTES b'*} + {TYPE `[n..m?] PAGE, BYTES b*} `<= {TYPE `[n'..m?] PAGE, BYTES b'*} -- if n <= n' -- if |b*| <= |b'*| rule Extend_tableinst: - {TYPE `[n..m] rt, REFS ref*} `<= {TYPE `[n'..m] rt, REFS ref'*} + {TYPE `[n..m?] rt, REFS ref*} `<= {TYPE `[n'..m?] rt, REFS ref'*} -- if n <= n' -- if |ref*| <= |ref'*| @@ -300,6 +300,6 @@ rule State_ok: -- Frame_ok: s |- f : C rule Config_ok: - |- s; f; instr* : t* + |- s; f; admininstr* : t* -- State_ok: |- s; f : C -- Expr_ok2: s; C |- admininstr* : t* diff --git a/specification/wasm-3.0/1.2-syntax.types.spectec b/specification/wasm-3.0/1.2-syntax.types.spectec index b30faaf4c0..a7855e18d0 100644 --- a/specification/wasm-3.0/1.2-syntax.types.spectec +++ b/specification/wasm-3.0/1.2-syntax.types.spectec @@ -398,7 +398,7 @@ def $subst_comptype((FUNC t_1* -> t_2*), tv*, tu*) = FUNC $subst_valtype(t_1, tv def $subst_subtype((SUB final? tu'* ct), tv*, tu*) = SUB final? $subst_typeuse(tu', tv*, tu*)* $subst_comptype(ct, tv*, tu*) -def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) hint(partial) +def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) hint(partial) hint(recfunc) def $minus_recs(eps, eps) = (eps, eps) def $minus_recs((REC n) tv*, tu_1 tu*) = $minus_recs(tv*, tu*) def $minus_recs((_IDX x) tv*, tu_1 tu*) = ((_IDX x) tv'*, tu_1 tu'*) diff --git a/specification/wasm-3.0/3.2-numerics.vector.spectec b/specification/wasm-3.0/3.2-numerics.vector.spectec index c88b9dadfb..a103f4059b 100644 --- a/specification/wasm-3.0/3.2-numerics.vector.spectec +++ b/specification/wasm-3.0/3.2-numerics.vector.spectec @@ -51,11 +51,11 @@ def $irelaxed_swizzle_lane_(N, c*, i) = $relaxed2($R_swizzle, iN(N), 0, c*[i \ | ;; Lanewise operations -def $ivunop_(shape, def $f_(N, iN(N)) : iN(N), vec_(V128)) : vec_(V128)* +def $ivunop_(shape, def $f_(N, iN(N)) : iN(N), vec_(V128)) : vec_(V128)* hint(partial) def $fvunop_(shape, def $f_(N, fN(N)) : fN(N)*, vec_(V128)) : vec_(V128)* -def $ivbinop_(shape, def $f_(N, iN(N), iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128)* -def $ivbinopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N), sx, vec_(V128), vec_(V128)) : vec_(V128)* +def $ivbinop_(shape, def $f_(N, iN(N), iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128)* hint(partial) +def $ivbinopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N), sx, vec_(V128), vec_(V128)) : vec_(V128)* hint(partial) def $ivbinopsxnd_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N)*, sx, vec_(V128), vec_(V128)) : vec_(V128)* def $fvbinop_(shape, def $f_(N, fN(N), fN(N)) : fN(N)*, vec_(V128), vec_(V128)) : vec_(V128)* @@ -66,12 +66,12 @@ def $ivrelop_(shape, def $f_(N, iN(N), iN(N)) : u32, vec_(V128), vec_(V128)) : v def $ivrelopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : u32, sx, vec_(V128), vec_(V128)) : vec_(V128) def $fvrelop_(shape, def $f_(N, fN(N), fN(N)) : u32, vec_(V128), vec_(V128)) : vec_(V128) -def $ivshiftop_(shape, def $f_(N, iN(N), u32) : iN(N), vec_(V128), u32) : vec_(V128) -def $ivshiftopsx_(shape, def $f_(N, sx, iN(N), u32) : iN(N), sx, vec_(V128), u32) : vec_(V128) +def $ivshiftop_(shape, def $f_(N, iN(N), u32) : iN(N), vec_(V128), u32) : vec_(V128) hint(partial) +def $ivshiftopsx_(shape, def $f_(N, sx, iN(N), u32) : iN(N), sx, vec_(V128), u32) : vec_(V128) hint(partial) def $ivbitmaskop_(shape, vec_(V128)) : u32 -def $ivswizzlop_(shape, def $f_(N, iN(N)*, iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128) -def $ivshufflop_(shape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) +def $ivswizzlop_(shape, def $f_(N, iN(N)*, iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128) hint(partial) +def $ivshufflop_(shape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) hint(partial) def $ivunop_(Jnn X M, def $f_, v_1) = $inv_lanes_(Jnn X M, c*) @@ -189,7 +189,7 @@ def $vbitmaskop_(ishape, vec_(V128)) : u32 hint(show VBITMASK#$_(%1,%2)) def $vswizzlop_(bshape, vswizzlop_(bshape), vec_(V128), vec_(V128)) : vec_(V128) hint(show %2#$_(%1,%3,%4)) -def $vshufflop_(bshape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) +def $vshufflop_(bshape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) hint(partial) hint(show VSHUFFLE#$_(%1,%2,%3,%4)) def $vnarrowop__(shape_1, shape_2, sx, vec_(V128), vec_(V128)) : vec_(V128) diff --git a/specification/wasm-3.0/7.1-soundness.configurations.spectec b/specification/wasm-3.0/7.1-soundness.configurations.spectec index 3ef64d767b..8f4382af93 100644 --- a/specification/wasm-3.0/7.1-soundness.configurations.spectec +++ b/specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -86,13 +86,13 @@ rule Globalinst_ok: -- Val_ok: s |- val : t rule Meminst_ok: - s |- {TYPE at `[n..m] PAGE, BYTES b*} : at `[n..m] PAGE - -- Memtype_ok: {} |- at `[n..m] PAGE : OK + s |- {TYPE at `[n..m?] PAGE, BYTES b*} : at `[n..m?] PAGE + -- Memtype_ok: {} |- at `[n..m?] PAGE : OK -- if |b*| = $(n * $($(64 * $Ki))) rule Tableinst_ok: - s |- {TYPE at `[n..m] rt, REFS ref*} : at `[n..m] rt - -- Tabletype_ok: {} |- at `[n..m] rt : OK + s |- {TYPE at `[n..m?] rt, REFS ref*} : at `[n..m?] rt + -- Tabletype_ok: {} |- at `[n..m?] rt : OK -- if |ref*| = n -- (Ref_ok: s |- ref : rt)* @@ -262,12 +262,12 @@ rule Extend_globalinst: -- if mut? = MUT \/ val = val' rule Extend_meminst: - {TYPE at `[n..m] PAGE, BYTES b*} `<= {TYPE at `[n'..m] PAGE, BYTES b'*} + {TYPE at `[n..m?] PAGE, BYTES b*} `<= {TYPE at `[n'..m?] PAGE, BYTES b'*} -- if n <= n' -- if |b*| <= |b'*| rule Extend_tableinst: - {TYPE at `[n..m] rt, REFS ref*} `<= {TYPE at `[n'..m] rt, REFS ref'*} + {TYPE at `[n..m?] rt, REFS ref*} `<= {TYPE at `[n'..m?] rt, REFS ref'*} -- if n <= n' -- if |ref*| <= |ref'*| diff --git a/specification/wasm-latest/1.2-syntax.types.spectec b/specification/wasm-latest/1.2-syntax.types.spectec index b30faaf4c0..a7855e18d0 100644 --- a/specification/wasm-latest/1.2-syntax.types.spectec +++ b/specification/wasm-latest/1.2-syntax.types.spectec @@ -398,7 +398,7 @@ def $subst_comptype((FUNC t_1* -> t_2*), tv*, tu*) = FUNC $subst_valtype(t_1, tv def $subst_subtype((SUB final? tu'* ct), tv*, tu*) = SUB final? $subst_typeuse(tu', tv*, tu*)* $subst_comptype(ct, tv*, tu*) -def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) hint(partial) +def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) hint(partial) hint(recfunc) def $minus_recs(eps, eps) = (eps, eps) def $minus_recs((REC n) tv*, tu_1 tu*) = $minus_recs(tv*, tu*) def $minus_recs((_IDX x) tv*, tu_1 tu*) = ((_IDX x) tv'*, tu_1 tu'*) diff --git a/specification/wasm-latest/3.2-numerics.vector.spectec b/specification/wasm-latest/3.2-numerics.vector.spectec index c88b9dadfb..a103f4059b 100644 --- a/specification/wasm-latest/3.2-numerics.vector.spectec +++ b/specification/wasm-latest/3.2-numerics.vector.spectec @@ -51,11 +51,11 @@ def $irelaxed_swizzle_lane_(N, c*, i) = $relaxed2($R_swizzle, iN(N), 0, c*[i \ | ;; Lanewise operations -def $ivunop_(shape, def $f_(N, iN(N)) : iN(N), vec_(V128)) : vec_(V128)* +def $ivunop_(shape, def $f_(N, iN(N)) : iN(N), vec_(V128)) : vec_(V128)* hint(partial) def $fvunop_(shape, def $f_(N, fN(N)) : fN(N)*, vec_(V128)) : vec_(V128)* -def $ivbinop_(shape, def $f_(N, iN(N), iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128)* -def $ivbinopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N), sx, vec_(V128), vec_(V128)) : vec_(V128)* +def $ivbinop_(shape, def $f_(N, iN(N), iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128)* hint(partial) +def $ivbinopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N), sx, vec_(V128), vec_(V128)) : vec_(V128)* hint(partial) def $ivbinopsxnd_(shape, def $f_(N, sx, iN(N), iN(N)) : iN(N)*, sx, vec_(V128), vec_(V128)) : vec_(V128)* def $fvbinop_(shape, def $f_(N, fN(N), fN(N)) : fN(N)*, vec_(V128), vec_(V128)) : vec_(V128)* @@ -66,12 +66,12 @@ def $ivrelop_(shape, def $f_(N, iN(N), iN(N)) : u32, vec_(V128), vec_(V128)) : v def $ivrelopsx_(shape, def $f_(N, sx, iN(N), iN(N)) : u32, sx, vec_(V128), vec_(V128)) : vec_(V128) def $fvrelop_(shape, def $f_(N, fN(N), fN(N)) : u32, vec_(V128), vec_(V128)) : vec_(V128) -def $ivshiftop_(shape, def $f_(N, iN(N), u32) : iN(N), vec_(V128), u32) : vec_(V128) -def $ivshiftopsx_(shape, def $f_(N, sx, iN(N), u32) : iN(N), sx, vec_(V128), u32) : vec_(V128) +def $ivshiftop_(shape, def $f_(N, iN(N), u32) : iN(N), vec_(V128), u32) : vec_(V128) hint(partial) +def $ivshiftopsx_(shape, def $f_(N, sx, iN(N), u32) : iN(N), sx, vec_(V128), u32) : vec_(V128) hint(partial) def $ivbitmaskop_(shape, vec_(V128)) : u32 -def $ivswizzlop_(shape, def $f_(N, iN(N)*, iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128) -def $ivshufflop_(shape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) +def $ivswizzlop_(shape, def $f_(N, iN(N)*, iN(N)) : iN(N), vec_(V128), vec_(V128)) : vec_(V128) hint(partial) +def $ivshufflop_(shape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) hint(partial) def $ivunop_(Jnn X M, def $f_, v_1) = $inv_lanes_(Jnn X M, c*) @@ -189,7 +189,7 @@ def $vbitmaskop_(ishape, vec_(V128)) : u32 hint(show VBITMASK#$_(%1,%2)) def $vswizzlop_(bshape, vswizzlop_(bshape), vec_(V128), vec_(V128)) : vec_(V128) hint(show %2#$_(%1,%3,%4)) -def $vshufflop_(bshape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) +def $vshufflop_(bshape, laneidx*, vec_(V128), vec_(V128)) : vec_(V128) hint(partial) hint(show VSHUFFLE#$_(%1,%2,%3,%4)) def $vnarrowop__(shape_1, shape_2, sx, vec_(V128), vec_(V128)) : vec_(V128) diff --git a/specification/wasm-latest/7.1-soundness.configurations.spectec b/specification/wasm-latest/7.1-soundness.configurations.spectec index 3ef64d767b..c2cda4333f 100644 --- a/specification/wasm-latest/7.1-soundness.configurations.spectec +++ b/specification/wasm-latest/7.1-soundness.configurations.spectec @@ -86,13 +86,13 @@ rule Globalinst_ok: -- Val_ok: s |- val : t rule Meminst_ok: - s |- {TYPE at `[n..m] PAGE, BYTES b*} : at `[n..m] PAGE - -- Memtype_ok: {} |- at `[n..m] PAGE : OK + s |- {TYPE at `[n..m?] PAGE, BYTES b*} : at `[n..m?] PAGE + -- Memtype_ok: {} |- at `[n..m?] PAGE : OK -- if |b*| = $(n * $($(64 * $Ki))) rule Tableinst_ok: - s |- {TYPE at `[n..m] rt, REFS ref*} : at `[n..m] rt - -- Tabletype_ok: {} |- at `[n..m] rt : OK + s |- {TYPE at `[n..m?] rt, REFS ref*} : at `[n..m?] rt + -- Tabletype_ok: {} |- at `[n..m?] rt : OK -- if |ref*| = n -- (Ref_ok: s |- ref : rt)* diff --git a/spectec/src/backend-rocq/disamb.ml b/spectec/src/backend-rocq/disamb.ml new file mode 100644 index 0000000000..8f1d91c931 --- /dev/null +++ b/spectec/src/backend-rocq/disamb.ml @@ -0,0 +1,188 @@ +open Il.Ast +open Util.Source +open Il.Walk +open Il +open Xl + +module StringMap = Map.Make(String) + +type env = { + mutable disamb_map: (string * string) list StringMap.t; + mutable il_env: Il.Env.t +} + +let new_env () = { + disamb_map = StringMap.empty; + il_env = Il.Env.empty +} + +let empty_info: region * Xl.Atom.info = (no_region, {def = ""; case = ""}) + +let env_ref: env ref = ref (new_env ()) + +let _print_env () = + List.iter (fun (typ_id, ss) -> + print_endline "Entry: "; + print_endline ("Type id: " ^ typ_id); + print_endline (String.concat " " (List.map (fun (base_id, _) -> base_id) ss)) + ) (StringMap.bindings !env_ref.disamb_map) + +let error at msg = Util.Error.error at "Rocq Generation" msg + +let (let*) = Option.bind + +let register_id typ_id base_id id = + !env_ref.disamb_map <- StringMap.update typ_id (fun opt -> + match opt with + | Some ss -> Some ((base_id, id) :: ss) + | None -> Some [(base_id, id)] + ) !env_ref.disamb_map + +let is_atomid a = + match a.it with + | Atom.Atom _ -> true + | _ -> false + +let get_atom_id a = + match a.it with + | Atom.Atom s -> s + | _ -> "" + +let get_mixop_s m = + String.concat "" (List.map ( + fun atoms -> String.concat "" (List.filter is_atomid atoms |> List.map get_atom_id)) (Xl.Mixop.flatten m) + ) + +let t_atom_opt typ_id a = + match a.it with + | Atom.Atom s -> + let* ss = StringMap.find_opt typ_id !env_ref.disamb_map in + let* _, s' = List.find_opt (fun (base_s, _) -> s = base_s) ss in + Some {a with it = Atom.Atom s'} + | _ -> Some a + +let t_atom typ_id a = + match (t_atom_opt typ_id a) with + | Some a -> a + | None -> error a.at "Could not find modified atom id" + +let t_mixop typ_id (m : mixop) = + match m with + (* | [a] :: tail when List.for_all ((=) []) tail -> [t_atom typ_id a] :: tail *) + | _ -> + let s = get_mixop_s m in + let new_atom = Atom.Atom s $$ empty_info in + Xl.Mixop.Atom (t_atom typ_id new_atom) + (* List.map (fun atoms -> List.map (t_atom typ_id) atoms) m *) + +let t_exp e = + match e.it with + | CaseE (m, e') -> + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env e.note) in + {e with it = CaseE (t_mixop name m, e')} + | StrE fields -> + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env e.note) in + let fields' = List.map (fun (a, e') -> (t_atom name a, e')) fields in + {e with it = StrE fields'} + | DotE (e', a) -> + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env e'.note) in + {e with it = DotE (e', t_atom name a)} + | _ -> e + +let t_path p = + match p.it with + | DotP (p', a) -> + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env p'.note) in + {p with it = DotP (p', t_atom name a)} + | _ -> p + +let rec t_rule_new rel_id base_r_id r_id = + let new_id = rel_id ^ "__" ^ r_id in + let lst = StringMap.bindings !env_ref.disamb_map in + begin match (List.find_opt (fun (_, ss) -> List.exists (fun (_, s') -> r_id = s') ss) lst) with + | Some _ -> t_rule_new rel_id base_r_id new_id + | None when + Il.Env.mem_typ !env_ref.il_env (r_id $ no_region) || + Il.Env.mem_def !env_ref.il_env (r_id $ no_region) -> + t_rule_new rel_id base_r_id new_id + | None -> + register_id rel_id base_r_id r_id; + r_id + end + +let rec t_atom_new typ_id base_a a = + match base_a.it, a.it with + | Atom.Atom base_s, Atom.Atom s -> + let lst = StringMap.bindings !env_ref.disamb_map in + begin match (List.find_opt (fun (_, ss) -> List.exists (fun (_, s') -> s = s') ss) lst) with + | Some _ -> + t_atom_new typ_id base_a {a with it = Xl.Atom.Atom (typ_id ^ "_" ^ s)} + | None when + Il.Env.mem_typ !env_ref.il_env (s $ no_region) || + Il.Env.mem_def !env_ref.il_env (s $ no_region) -> + t_atom_new typ_id base_a {a with it = Xl.Atom.Atom (typ_id ^ "_" ^ s)} + | None -> + register_id typ_id base_s s; + {a with it = Atom.Atom s} + end + | _-> a + +let t_mixop_new typ_id m = + match m with + (* | [a] :: tail when List.for_all ((=) []) tail -> [t_atom_new typ_id a a] :: tail *) + | _ -> + let s = get_mixop_s m in + let new_atom = Atom.Atom s $$ empty_info in + Xl.Mixop.Atom (t_atom_new typ_id new_atom new_atom) + + + (* List.map (fun atoms -> List.map (fun a -> t_atom_new typ_id a a) atoms) m *) + +let t_inst t typ_id inst = + let InstD (quants, args, deftyp) = inst.it in + let deftyp' = match deftyp.it with + | VariantT typcases -> VariantT (List.map (fun (m, (typ, quants', prems), h) -> + (t_mixop_new typ_id m, + (transform_typ t typ, List.map (transform_param t) quants', List.map (transform_prem t) prems), + h) + ) typcases) + | StructT typfields -> StructT (List.map (fun (a, (typ, quants', prems), h) -> + (t_atom_new typ_id a a, (transform_typ t typ, List.map (transform_param t) quants', List.map (transform_prem t) prems), h) + ) typfields) + | AliasT typ -> AliasT (transform_typ t typ) in + { inst with it = InstD (List.map (transform_param t) quants, List.map (transform_arg t) args, {deftyp with it = deftyp'})} + +let rec t_def def = + let t = { base_transformer with transform_path = t_path; transform_exp = t_exp } in + match def.it with + | TypD (typ_id, params, insts) -> + { def with it = TypD (typ_id, List.map (transform_param t) params, List.map (t_inst t typ_id.it) insts) } + | RecD defs -> { def with it = RecD (List.map t_def defs) } + | RelD (id, ps, m, typ, rules) -> + { def with it = RelD (id, ps, m, typ, + List.map (fun rule -> + let RuleD (r_id, quants, m, exp, prems) = rule.it in + { rule with it = RuleD ((t_rule_new id.it r_id.it r_id.it) $ r_id.at, + List.map (transform_param t) quants, m, transform_exp t exp, List.map (transform_prem t) prems) } + ) rules) } + | _ -> transform_def t def + +(* Remove overlaps created by sub expansion *) +let remove_overlapping_clauses clauses = + Util.Lib.List.nub (fun clause clause' -> match clause.it, clause'.it with + | DefD (_, args, exp, _), DefD (_, args', exp', _) -> + let reduced_exp = Eval.reduce_exp !env_ref.il_env exp in + let reduced_exp' = Eval.reduce_exp !env_ref.il_env exp' in + Eq.eq_list Eq.eq_arg args args' && Eq.eq_exp reduced_exp reduced_exp' + ) clauses + +let rec rem_overlap_def def = + match def.it with + | DecD (id, params, typ, clauses) -> {def with it = DecD (id, params, typ, remove_overlapping_clauses clauses)} + | RecD defs -> {def with it = RecD (List.map rem_overlap_def defs)} + | _ -> def + +let transform il = + !env_ref.il_env <- Il.Env.env_of_script il; + List.map rem_overlap_def il |> + List.map t_def \ No newline at end of file diff --git a/spectec/src/backend-rocq/dune b/spectec/src/backend-rocq/dune new file mode 100644 index 0000000000..a9b1519f67 --- /dev/null +++ b/spectec/src/backend-rocq/dune @@ -0,0 +1,5 @@ +(library + (name backend_rocq) + (libraries il middlend xl) + (modules print disamb) +) diff --git a/spectec/src/backend-rocq/print.ml b/spectec/src/backend-rocq/print.ml new file mode 100644 index 0000000000..3476e7adb5 --- /dev/null +++ b/spectec/src/backend-rocq/print.ml @@ -0,0 +1,1035 @@ +open Il.Ast +open Util.Source +open Il.Walk + +module StringSet = Set.Make(String) +module StringMap = Map.Make(String) +type rocq_env = { + mutable tf_set : StringSet.t; + mutable il_env : Il.Env.t; + mutable proj_set : StringSet.t; + mutable wf_lemma_set : StringSet.t; + mutable typ_to_wf_map : text StringMap.t +} + +let new_env () = { + tf_set = StringSet.empty; + il_env = Il.Env.empty; + proj_set = StringSet.empty; + wf_lemma_set = StringSet.empty; + typ_to_wf_map = StringMap.empty +} + +let iter_prem_rels_list = ["List.Forall"; "List.Forall2"; "List_Forall3"] +let iter_exp_lst_funcs = ["seq.map"; "list_zipWith"; "list_map3"] +let sup_iter_prem_rels_list = ["List_Foralli"] +let iter_exp_opt_funcs = ["option_map"; "option_zipWith"; "option_map3"] +let error at msg = Util.Error.error at "Rocq translation" msg + +let env_ref = ref (new_env ()) + +let is_let p = + match p.it with + | LetPr _ -> true + | _ -> false + +let rec list_split (f : 'a -> bool) = function + | [] -> ([], []) + | x :: xs when f x -> let x_true, x_false = list_split f xs in + (x :: x_true, x_false) + | xs -> ([], xs) + +let rec is_type_family t = + match t.it with + | VarT (id, _) -> StringSet.mem id.it !env_ref.tf_set + | IterT (t', _) -> is_type_family t' + | TupT typs -> List.exists (fun (_, t') -> is_type_family t') typs + | _ -> false + +let is_type_family_param p = + match p.it with + | ExpP (_, t) -> is_type_family t + | _ -> false + +let get_type_var t = + match t.it with + | VarT (id, _) when not (Il.Env.mem_typ !env_ref.il_env id) -> [id.it] + | _ -> [] + +let needs_inh_class e = + match e.it with + | IdxE _ | TheE _ -> (get_type_var e.note, false) + | _ -> ([], true) + +let needs_inh_class_path p = + match p.it with + | IdxP _ -> (get_type_var p.note, false) + | _ -> ([], true) + +type exptype = + | LHS + | RHS + | REL + +let var_prefix = "var_" + +(* let render_rule_id rel_id id = rel_id ^ "__" ^ id *) + +let reserved_ids = + ["N"; "in"; "In"; + "S"; + "return"; + "if"; + "bool"; + "prod"; + "at"; + "()"; "tt"; + "Import"; "Export"; + "seq"; + "List"; "String"; + "Type"; "list"; "nat"; "int"; "rat"; + "cons"] |> StringSet.of_list + +let remove_iter_from_type t = + match t.it with + | IterT (t', _) -> t' + | _ -> t +let empty_name s = match s with + | "" -> "NO_NAME" + | _ -> s + +let is_typ_quant b = match b.it with + | TypP _ -> true + | _ -> false + +let string_of_list_prefix prefix delim str_func ls = + match ls with + | [] -> "" + | _ -> prefix ^ String.concat delim (List.map str_func ls) + +let string_of_list_suffix suffix delim str_func ls = + match ls with + | [] -> "" + | _ -> String.concat delim (List.map str_func ls) ^ suffix + +let string_of_list prefix suffix delim str_func ls = + match ls with + | [] -> "" + | _ -> prefix ^ String.concat delim (List.map str_func ls) ^ suffix + +let square_parens s = "[" ^ s ^ "]" +let ssreflect_square_parens s = "[::" ^ s ^ "]" +let parens s = "(" ^ s ^ ")" +let curly_parens s = "{" ^ s ^ "}" +let comment_parens s = "(* " ^ s ^ " *)" +let line_parens spc s = "|" ^ spc ^ s ^ spc ^ "|" + +let op_parens optyp s = + match optyp with + | `NatT -> parens s ^ "%N" + | `IntT -> parens s ^ "%Z" + | `RatT -> parens s ^ "%Q" + | `RealT -> parens s ^ "%nat" (* TODO *) + | _ -> parens s + +let family_type_suffix = "entry" + +let is_record_typ inst = + match inst.it with + | InstD (_, _, {it = StructT _; _}) -> true + | _ -> false + +let is_variant_typ inst = + match inst.it with + | InstD (_, _, {it = VariantT _; _}) -> true + | _ -> false + +let is_alias_typ inst = + match inst.it with + | InstD (_, _, {it = AliasT _; _}) -> true + | _ -> false + +let is_alias_typ_def def = + match def.it with + | TypD(_ , _, [{it = InstD (_, _, {it = AliasT _; _}); _}]) -> true + | _ -> false + +let check_trivial_append env typ = + match typ.it with + | IterT _ -> true + | VarT (id, _) -> + begin match (Il.Env.find_opt_typ env id) with + | Some (_, [inst]) when is_record_typ inst -> true + | _ -> false + end + | _ -> false + +let is_inductive d = + match d.it with + | RelD _ -> true + | TypD(_, _, [inst]) when is_variant_typ inst || is_alias_typ inst -> true + | _ -> false + +let comment_desc_def d = + match d.it with + | TypD (_, _, [inst]) when is_alias_typ inst -> "Type Alias Definition" + | TypD (_, _, [inst]) when is_variant_typ inst -> "Inductive Type Definition" + | TypD (_, _, [inst]) when is_record_typ inst -> "Record Creation Definition" + | TypD _ -> "Type Family Definition" + | RecD _ -> "Mutual Recursion" + | DecD (_, _, _, []) -> "Axiom Definition" + | DecD _ -> "Auxiliary Definition" + | RelD _ -> "Inductive Relations Definition" + | HintD _ -> "Hint Definition" + | GramD _ -> "Grammar Production Definition" + +let render_unop unop = + match unop with + | `NotOp -> "negb " + | `PlusOp -> "" + | `MinusOp -> "0 - " +let render_binop binop = + match binop with + | `AndOp -> " && " + | `OrOp -> " || " + | `ImplOp -> " -> " + | `EquivOp -> " <-> " + | `AddOp -> " + " + | `SubOp -> " - " + | `MulOp -> " * " + | `DivOp -> " / " + | `ModOp -> " mod " + | `PowOp -> " ^ " + +let render_cmpop cmpop = + match cmpop with + | `EqOp -> " == " + | `NeOp -> " != " + | `LtOp -> " < " + | `GtOp -> " > " + | `LeOp -> " <= " + | `GeOp -> " >= " + +let is_atomid a = + match a.it with + | Xl.Atom.Atom _ -> true + | _ -> false + +let render_id id = + match id with + | s when StringSet.mem s reserved_ids -> "res_" ^ s + | _ -> id + +let render_atom ?(in_mixop = false) a = + match a.it with + | Xl.Atom.Atom a when in_mixop -> a + | Xl.Atom.Atom a -> render_id a + | _ -> "" + +let render_mixop typ_id (m : mixop) = + let s = (match m with + (* | [{it = Atom a; _}] :: tail when List.for_all ((=) []) tail -> render_id a *) + | mixop -> String.concat "" (List.map ( + fun atoms -> String.concat "" (List.filter is_atomid atoms |> List.map (render_atom ~in_mixop:true))) (Xl.Mixop.flatten mixop) + ) + ) in + (* HACK - should be done in improve ids *) + match s with + | "_" -> "mk_" ^ typ_id + | s when Il.Env.mem_typ !env_ref.il_env (s $ no_region) -> "mk_" ^ s + | s -> s + +let get_param_id b = + match b.it with + | ExpP (id, _) | TypP id | DefP (id, _, _) | GramP (id, _, _) -> render_id id.it + +let render_numtyp nt = + match nt with + | `NatT -> "nat" + | `IntT -> "int" + | `RatT -> "rat" + | `RealT -> "R" + +let transform_case_tup e = + match e.it with + | TupE exps -> exps + | _ -> [e] + +let transform_case_typ t = + match t.it with + | TupT typs -> List.map snd typs + | _ -> [t] + +let transform_case_args t = + match t.it with + | TupT typs -> typs + | _ -> [("_" $ t.at, t)] + +let get_type_args t = + match t.it with + | VarT (_, args) -> args + | _ -> error t.at ("Following type should be a variable type: " ^ Il.Print.string_of_typ t) + +let rec render_param_type exp_type param = + match param.it with + | ExpP (_, typ) -> render_type exp_type typ + | TypP _ -> "eqType" + | DefP (_, params, typ) -> + string_of_list_suffix " -> " " -> " (render_param_type exp_type) params ^ render_type exp_type typ + | GramP _ -> comment_parens ("Unsupported param: " ^ Il.Print.string_of_param param) + +and render_type exp_type typ = + let rt_func = render_type exp_type in + match typ.it with + | VarT (id, []) -> render_id id.it + | VarT (id, args) -> parens (render_id id.it ^ " " ^ String.concat " " (List.map (render_arg exp_type) args)) + | BoolT -> "bool" + | NumT nt -> render_numtyp nt + | TextT -> "string" + | TupT [] -> "unit" + | TupT typs -> parens (String.concat " * " (List.map (fun (_, t) -> rt_func t) typs)) + | IterT (t, Opt) -> parens ("option " ^ rt_func t) + | IterT (t, _) -> parens ("seq " ^ rt_func t) + +and render_exp exp_type exp = + let r_func = render_exp exp_type in + match exp.it with + | VarE id -> render_id id.it + | BoolE b -> string_of_bool b + | NumE (`Nat n) -> Z.to_string n (* TODO fix nums *) + | NumE (`Int n) -> Z.to_string n (* TODO fix nums *) + | NumE (`Rat n) -> Q.to_string n (* TODO fix nums *) + | NumE (`Real n) -> string_of_float n (* TODO fix nums *) + | TextE s -> "\"" ^ String.escaped s ^ "\"" + | UnE (unop, optyp, e1) -> op_parens optyp (render_unop unop ^ r_func e1) + | BinE (binop, optyp, e1, e2) -> op_parens optyp (r_func e1 ^ render_binop binop ^ r_func e2) + | CmpE (cmpop, optyp, e1, e2) -> op_parens optyp (r_func e1 ^ render_cmpop cmpop ^ r_func e2) + | TupE [] -> "()" + | TupE exps -> parens (String.concat ", " (List.map r_func exps)) + | ProjE (e, i) -> + let typs = transform_case_typ e.note in + let rec make_proj_chain idx len e = + match idx, len with + | 0, 0 -> r_func e + | i', n when i' >= n -> r_func e ^ ".2" + | _ -> (make_proj_chain idx (len - 1) e) ^ ".1" + in + begin match typs with + | [_] -> r_func e + | _ -> make_proj_chain i (List.length typs - 1) e + end + | CaseE (m, e) when exp_type = LHS -> + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env exp.note) |> render_id in + let exps = transform_case_tup e in + begin match exps with + | [] -> render_mixop name m + | _ -> parens (render_mixop name m ^ " " ^ String.concat " " (List.map r_func exps)) + end + | CaseE (m, e) -> + let exps = transform_case_tup e in + let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env exp.note) |> render_id in + (* Reduce here to remove type aliasing *) + let args = get_type_args (Il.Eval.reduce_typ !env_ref.il_env exp.note) in + let implicit_args = if args = [] then "" else " " ^ String.concat " " (List.init (List.length args) (fun _ -> "_")) in + begin match exps with + | [] -> render_mixop name m + | _ -> parens (render_mixop name m ^ implicit_args ^ " " ^ String.concat " " (List.map r_func exps)) + end + | UncaseE _ -> error exp.at "Encountered uncase. Run uncase-removal pass" + | OptE (Some e) -> parens ("Some " ^ r_func e) + | OptE None -> "None" + | TheE e -> parens ("!" ^ parens (r_func e)) + | StrE fields -> "{| " ^ (String.concat "; " (List.map (fun (a, e) -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env exp.note) |> render_id in *) + render_atom a ^ " := " ^ r_func e) fields)) ^ " |}" + | DotE (e, a) -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env e.note) |> render_id in *) + parens (render_atom a ^ " " ^ r_func e) + | CompE (e1, e2) -> parens (r_func e1 ^ " @@ " ^ r_func e2) + | ListE [] -> "[:: ]" + | ListE exps -> ssreflect_square_parens (String.concat "; " (List.map r_func exps)) + | LiftE e -> parens ("option_to_list " ^ r_func e) + | MemE (e1, e2) -> parens (r_func e1 ^ " \\in " ^ r_func e2) + | LenE e1 -> parens (line_parens "" (r_func e1)) + | CatE ({it = ListE [e1]; _}, e2) when exp_type = LHS -> parens (r_func e1 ^ " :: " ^ r_func e2) + | CatE (e1, e2) -> parens (r_func e1 ^ " ++ " ^ r_func e2) + | IdxE (e1, e2) -> parens (r_func e1 ^ square_parens (line_parens " " (r_func e2))) + | SliceE (e1, e2, e3) -> parens ("list_slice " ^ r_func e1 ^ " " ^ r_func e2 ^ " " ^ r_func e3) + | UpdE (e1, p, e2) -> render_path_start p e1 false e2 + | ExtE (e1, p, e2) -> render_path_start p e1 true e2 + | CallE (id, [a]) when StringSet.mem id.it !env_ref.proj_set -> + parens (render_arg exp_type a ^ " :> " ^ (render_type exp_type exp.note)) + | CallE (id, args) -> parens (render_id id.it ^ " " ^ String.concat " " (List.map (render_arg exp_type) args)) + (* Iter handling *) + | IterE (e, (ListN (n, Some id), [])) -> + parens ("seq.mkseq " ^ render_lambda [id.it] (r_func e) ^ " " ^ (r_func n)) + | IterE (e, (ListN (n, None), [])) -> parens ("List.repeat " ^ (r_func e) ^ " " ^ (r_func n)) + | IterE (e, (_, [])) -> r_func e + | IterE (e, _) when exp_type = LHS -> r_func e + | IterE (e, (iter, iter_quants)) -> + let quants = List.map (fun (id, e) -> parens (render_id id.it ^ " : " ^ render_type exp_type (remove_iter_from_type e.note))) iter_quants in + let iter_exps = List.map snd iter_quants in + let n = List.length iter_quants - 1 in + let lst = if iter = Opt then iter_exp_opt_funcs else iter_exp_lst_funcs in + let pred_name = match (List.nth_opt lst n) with + | Some s -> s + | None -> error exp.at "Iteration exceeded the supported amount for rocq translation" + in + parens (pred_name ^ " " ^ render_lambda quants (r_func e) ^ " " ^ + String.concat " " (List.map (render_exp exp_type) iter_exps)) + | CvtE (e1, _nt1, nt2) -> parens (r_func e1 ^ " : " ^ render_numtyp nt2) + | SubE _ -> error exp.at "Encountered subtype expression. Please run sub pass" + | IfE (e1, e2, e3) -> parens ("if " ^ r_func e1 ^ " then " ^ r_func e2 ^ " else " ^ r_func e3) + +and render_arg exp_type a = + match a.it with + | ExpA e -> render_exp exp_type e + | TypA t -> render_type exp_type t + | DefA id -> render_id id.it + | _ -> comment_parens ("Unsupported arg: " ^ Il.Print.string_of_arg a) + +and render_quant exp_type b = + match b.it with + | ExpP (id, typ) -> parens (render_id id.it ^ " : " ^ render_type exp_type typ) + | TypP id -> parens (render_id id.it ^ " : Type") + | DefP (id, params, typ) -> + parens (render_id id.it ^ " : " ^ + string_of_list_suffix " -> " " -> " (render_param_type exp_type) params ^ + render_type exp_type typ) + | GramP _ -> comment_parens ("Unsupported quant: " ^ Il.Print.string_of_quant b) + +and render_param exp_type param = + parens (get_param_id param ^ " : " ^ render_param_type exp_type param) + +(* PATH Functions *) +and transform_list_path (p : path) = + match p.it with + | RootP -> [] + | IdxP (p', _) | SliceP (p', _, _) | DotP (p', _) when p'.it = RootP -> [] + | IdxP (p', _) | SliceP (p', _, _) | DotP (p', _) -> p' :: transform_list_path p' + +and render_lambda quants text = + parens ("fun " ^ String.concat " " quants ^ " => " ^ text) + +and render_path_start (p : path) start_exp is_extend end_exp = + let paths = List.rev (p :: transform_list_path p) in + (render_path paths (start_exp.note) p.at 0 (Some start_exp) is_extend end_exp) + +and render_path (paths : path list) typ at n name is_extend end_exp = + let render_record_update t1 t2 t3 = + parens (t1 ^ " <| " ^ t2 ^ " := " ^ t3 ^ " |>") + in + let r_func_e = render_exp RHS in + let is_dot p = (match p.it with + | DotP _ -> true + | _ -> false + ) in + let list_name num = (match name with + | Some exp -> exp + | None -> VarE ((var_prefix ^ string_of_int num) $ no_region) $$ no_region % typ + ) in + let new_name_typ = remove_iter_from_type (list_name n).note in + let new_name = var_prefix ^ string_of_int (n + 1) in + match paths with + (* End logic for extend *) + | [{it = IdxP (_, e); _}] when is_extend -> + let extend_term = parens (new_name ^ " ++ " ^ r_func_e end_exp) in + let quant = render_quant RHS (ExpP (new_name $ no_region, new_name_typ) $ no_region) in + parens ("list_update_func " ^ r_func_e (list_name n) ^ " " ^ r_func_e e ^ render_lambda [quant] extend_term) + | [{it = DotP (_p, a); _}] when is_extend -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env p.note) |> render_id in *) + let projection_term = parens (render_atom a ^ " " ^ r_func_e (list_name n)) in + let extend_term = parens (projection_term ^ " ++ " ^ r_func_e end_exp) in + render_record_update (r_func_e (list_name n)) (render_atom a) extend_term + | [{it = SliceP (_, e1, e2); _}] when is_extend -> + let extend_term = parens (new_name ^ " ++ " ^ r_func_e end_exp) in + let quant = render_quant RHS (ExpP (new_name $ no_region, new_name_typ) $ no_region) in + parens ("list_slice_update " ^ r_func_e (list_name n) ^ " " ^ r_func_e e1 ^ " " ^ r_func_e e2 ^ " " ^ render_lambda [quant] extend_term) + (* End logic for update *) + | [{it = IdxP (_, e); _}] -> + let quant = render_quant RHS (ExpP ("_" $ no_region, new_name_typ) $ no_region) in + parens ("list_update_func " ^ r_func_e (list_name n) ^ " " ^ r_func_e e ^ " " ^ render_lambda [quant] (r_func_e end_exp)) + | [{it = DotP (_p, a); _}] -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env p.note) |> render_id in *) + render_record_update (r_func_e (list_name n)) (render_atom a) (r_func_e end_exp) + | [{it = SliceP (_, e1, e2); _}] -> + parens ("list_slice_update " ^ r_func_e (list_name n) ^ " " ^ r_func_e e1 ^ " " ^ r_func_e e2 ^ " " ^ r_func_e end_exp) + (* Middle logic *) + | {it = IdxP (_, e); note; _} :: ps -> + let path_term = render_path ps note at (n + 1) None is_extend end_exp in + let new_name = var_prefix ^ string_of_int (n + 1) in + let quant = render_quant RHS (ExpP (new_name $ no_region, new_name_typ) $ no_region) in + parens ("list_update_func " ^ r_func_e (list_name n) ^ " " ^ r_func_e e ^ " " ^ render_lambda [quant] path_term) + | ({it = DotP _; note; _} as p) :: ps -> + let (dot_paths, ps') = list_split is_dot (p :: ps) in + let (end_name, end_atom, dot_paths') = match List.rev dot_paths with + | {it = DotP (_p, a'); _} :: ds -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env p.note) |> render_id in *) + (render_atom a', a', ds) + | _ -> assert false (* Impossible since it has p *) + in + let projection_term = List.fold_right (fun p acc -> + match p.it with + | DotP (_, a') -> + DotE (acc, a') $$ no_region % p.note + | _ -> error at "Should be a record access" (* Should not happen *) + ) dot_paths' (list_name n) in + let update_fields = String.concat ";" (List.map (fun p -> + match p.it with + | DotP (_p', a) -> + (* let name = Il.Print.string_of_typ_name (Il.Eval.reduce_typ !env_ref.il_env p'.note) |> render_id in *) + render_atom a + | _ -> error at "Should be a record access" + ) dot_paths) in + let new_term = parens (end_name ^ " " ^ r_func_e projection_term) in + let new_exp = DotE (projection_term, end_atom) $$ no_region % note in + if ps' = [] + then ( + let final_term = if is_extend then parens (new_term ^ " ++ " ^ r_func_e end_exp) else r_func_e end_exp in + render_record_update (r_func_e (list_name n)) update_fields final_term + ) + else ( + let path_term = render_path ps' note at n (Some new_exp) is_extend end_exp in + render_record_update (r_func_e (list_name n)) update_fields path_term + ) + | ({it = SliceP (_, _e1, _e2); _} as p) :: _ps -> + (* TODO - this is not entirely correct. Still unsure how to implement this as a term *) + (* let new_typ = transform_type' NORMAL note in + let path_term = render_path ps new_typ at (n + 1) None is_extend end_exp $@ transform_type' NORMAL note in + let new_name = var_prefix ^ string_of_int (n + 1) in + let lambda_typ = T_arrowtype [new_name_typ; new_typ] in + T_app (T_exp_basic T_sliceupdate $@ anytype', + [list_name n; transform_exp NORMAL e1; transform_exp NORMAL e2; T_lambda ([(new_name, new_name_typ)], path_term) $@ lambda_typ]) *) + comment_parens (Il.Print.string_of_path p) + (* Catch all error if we encounter empty list or RootP *) + | _ -> error at "Paths should not be empty" + +and render_quants (quants : quant list) = + string_of_list_prefix " " " " (render_quant RHS) quants + +let render_quants_ids (quants : quant list) = + string_of_list_prefix " " " " get_param_id quants + +let render_match_quanters params = + String.concat ", " (List.map get_param_id params) + +let render_params params = + string_of_list_prefix " " " " (render_param RHS) params + +let render_match_args args = + string_of_list_prefix " " ", " (render_arg LHS) args + +let string_of_eqtype_proof recursive (cant_do_equality: bool) id (quants : quant list) = + let quanters = render_quants quants in + let quanter_ids = render_quants_ids quants in + let id' = render_id id in + (* Decidable equality proof *) + (* e.g. + Definition functype_eq_dec : forall (tf1 tf2 : functype), + {tf1 = tf2} + {tf1 <> tf2}. + Proof. decidable_equality. Defined. + Definition functype_eqb v1 v2 : bool := functype_eq_dec v1 v2. + Definition eqfunctypeP : Equality.axiom functype_eqb := + eq_dec_Equality_axiom functype functype_eq_dec. + + HB.instance Definition _ := hasDecEq.Build (functype) (eqfunctypeP). + *) + (if cant_do_equality then comment_parens "FIXME - No clear way to do decidable equality" ^ "\n" else "") ^ + (match recursive with + | true -> + + "Fixpoint " ^ id' ^ "_eq_dec" ^ quanters ^ " (v1 v2 : " ^ id' ^ quanter_ids ^ ") {struct v1} :\n" ^ + " {v1 = v2} + {v1 <> v2}.\n" ^ + let proof = if cant_do_equality then "Admitted" else "decide equality; do ? decidable_equality_step. Defined" in + "Proof. " ^ proof ^ ".\n\n" + | false -> + "Definition " ^ id' ^ "_eq_dec : forall" ^ quanters ^ " (v1 v2 : " ^ id' ^ quanter_ids ^ "),\n" ^ + " {v1 = v2} + {v1 <> v2}.\n" ^ + + let proof = if cant_do_equality then "Admitted" else "do ? decidable_equality_step. Defined" in + "Proof. " ^ proof ^ ".\n\n") ^ + + "Definition " ^ id' ^ "_eqb" ^ quanters ^ " (v1 v2 : " ^ id' ^ quanter_ids ^ ") : bool :=\n" ^ + "\tis_left" ^ parens (id' ^ "_eq_dec" ^ quanter_ids ^ " v1 v2") ^ ".\n" ^ + "Definition eq" ^ id' ^ "P" ^ quanters ^ " : Equality.axiom " ^ parens (id' ^ "_eqb" ^ quanter_ids) ^ " :=\n" ^ + "\teq_dec_Equality_axiom " ^ parens (id' ^ quanter_ids) ^ " " ^ parens (id' ^ "_eq_dec" ^ quanter_ids) ^ ".\n\n" ^ + "HB.instance Definition _" ^ quanters ^ " := hasDecEq.Build " ^ parens (id' ^ quanter_ids) ^ " " ^ parens ("eq" ^ id' ^ "P" ^ quanter_ids) ^ ".\n" ^ + "Hint Resolve " ^ id' ^ "_eq_dec : eq_dec_db" + +let string_of_relation_args typ = + string_of_list "" " -> " " -> " (render_type REL) (transform_case_typ typ) + +let rec render_prem prem = + let r_func = render_prem in + match prem.it with + | IfPr exp -> render_exp REL exp + | RulePr (id, args, _m, exp) -> parens (render_id id.it ^ string_of_list_prefix " " " " (render_arg REL) args ^ + string_of_list_prefix " " " " (render_exp REL) (transform_case_tup exp)) + | NegPr p -> parens ("~" ^ r_func p) + | ElsePr -> "True " ^ comment_parens ("Unsupported premise: otherwise") (* Will be removed by an else pass *) + | IterPr (p, (ListN (e, Some i), [])) -> + let pred_name = "holds_upto" in + pred_name ^ " " ^ render_lambda [i.it] (r_func p) ^ " " ^ (render_exp REL e) + | IterPr (p, (_, [])) -> r_func p + | IterPr (p, (ListN (_, Some i), ps)) -> + let quants = List.map (fun (id, e) -> parens (render_id id.it ^ " : " ^ render_type REL (remove_iter_from_type e.note))) ps in + let iter_exps = List.map snd ps in + let n = List.length ps - 1 in + let pred_name = match (List.nth_opt sup_iter_prem_rels_list n) with + | Some s -> s + | None -> error prem.at "Iteration exceeded the supported amount for rocq translation" + in + pred_name ^ " " ^ render_lambda (i.it :: quants) (r_func p) ^ " " ^ + String.concat " " (List.map (render_exp REL) iter_exps) + | IterPr (p, (iter, ps)) -> + let option_conversion s = if iter = Opt then parens ("option_to_list " ^ s) else s in + let quants = List.map (fun (id, e) -> parens (render_id id.it ^ " : " ^ render_type REL (remove_iter_from_type e.note))) ps in + let iter_exps = List.map snd ps in + let n = List.length ps - 1 in + let pred_name = match (List.nth_opt iter_prem_rels_list n) with + | Some s -> s + | None -> error prem.at "Iteration exceeded the supported amount for rocq translation" + in + pred_name ^ " " ^ render_lambda quants (r_func p) ^ " " ^ + String.concat " " (List.map (render_exp REL) iter_exps |> List.map option_conversion) + | LetPr (_, e1, e2) -> + "let " ^ render_exp LHS e1 ^ " := " ^ render_exp RHS e2 ^ " in " + +let render_typealias id quants typ = + "Definition " ^ id ^ render_quants quants ^ " : Type := " ^ render_type RHS typ + +let render_record recursive id quants fields = + let constructor_name = "MK" ^ id in + let inhabitance_quanters = render_quants quants in + let quanters = render_quants_ids quants in + + (* Standard Record definition *) + "Record " ^ id ^ inhabitance_quanters ^ " := " ^ constructor_name ^ "\n{\t" ^ + String.concat "\n;\t" (List.map (fun (a, (typ, _, _), _) -> + render_atom a ^ " : " ^ render_type RHS typ) fields) ^ "\n}.\n\n" ^ + + (* Inhabitance proof for default values *) + "Global Instance Inhabited_" ^ id ^ inhabitance_quanters ^ " : Inhabited " ^ parens (id ^ quanters) ^ " := \n" ^ + "{default_val := {|\n\t" ^ + String.concat ";\n\t" (List.map (fun (a, _, _) -> + render_atom a ^ " := default_val") fields) ^ "|} }.\n\n" ^ + + (* Append instance *) + "Definition _append_" ^ id ^ inhabitance_quanters ^ " (arg1 arg2 : " ^ parens (id ^ quanters) ^ ") :=\n" ^ + "{|\n\t" ^ String.concat "\t" ((List.map (fun (a, (t, _, _), _) -> + let record_id' = render_atom a in + if (check_trivial_append !env_ref.il_env t) + then record_id' ^ " := " ^ "arg1.(" ^ record_id' ^ ") @@ arg2.(" ^ record_id' ^ ");\n" + else record_id' ^ " := " ^ "arg1.(" ^ record_id' ^ "); " ^ comment_parens "FIXME - Non-trivial append" ^ "\n" + )) fields) ^ "|}.\n\n" ^ + "Global Instance Append_" ^ id ^ " : Append " ^ id ^ " := { _append arg1 arg2 := _append_" ^ id ^ " arg1 arg2 }.\n\n" ^ + + (* Setter proof *) + "#[export] Instance eta__" ^ id ^ " : Settable _ := settable! " ^ constructor_name ^ " <" ^ + String.concat ";" (List.map (fun (a, _, _) -> render_atom a) fields) ^ ">" + ^ ".\n\n" ^ string_of_eqtype_proof recursive false id [] + +let rec has_typ id t = + match t.it with + | VarT (id', _) -> id'.it = id + | IterT (t', _) -> has_typ id t' + | TupT pairs -> List.exists (fun (_, t') -> has_typ id t') pairs + | _ -> false + +let inhabitance_proof id quants cases = + (* Inhabitance proof for default values *) + let inhabitance_quanters = render_quants quants in + let quanters = render_quants_ids quants in + "Global Instance Inhabited__" ^ id ^ inhabitance_quanters ^ " : Inhabited " ^ parens (id ^ quanters) ^ + let rec render_proof cs = + (match cs with + | [] -> "(* FIXME: no inhabitant found! *) .\n" ^ + "\tAdmitted" + | (m, (t, _, _), _) :: ts -> + let typs = transform_case_typ t in + if (List.exists (has_typ id) typs) then render_proof ts else + " := { default_val := " ^ render_mixop id m ^ quanters ^ + string_of_list_prefix " " " " (fun _ -> "default_val" ) (transform_case_typ t) ^ " }") + in + render_proof cases + +let render_coercion (base_typ_id, typ_params) coerc_typ_id proj_func_id = + "Global Instance " ^ proj_func_id ^ "_coercion" ^ render_params typ_params ^ " : Coercion " ^ base_typ_id ^ " " ^ coerc_typ_id ^ " := { coerce := " ^ proj_func_id ^ + string_of_list_prefix " " " " get_param_id typ_params ^ " }" + +let cant_do_equality quants cases = + (List.exists is_typ_quant quants) || + (List.exists (fun (_, (_, quants', _), _) -> List.exists is_typ_quant quants') cases) + +let render_case_typs t = + let typs = transform_case_args t in + string_of_list_prefix " " " " (fun (i, t) -> + parens (render_id i.it ^ " : " ^ render_type RHS t)) typs + +let render_variant_typ is_recursive prefix id quants cases = + prefix ^ id ^ render_quants quants ^ " : Type :=\n\t" ^ + String.concat "\n\t" (List.map (fun (m, (t, _, _), _) -> + "| " ^ render_mixop id m ^ render_case_typs t ^ " : " ^ id ^ render_quants_ids quants + ) cases) ^ + if is_recursive then "" else + (* Inhabitance proof *) + ".\n\n" ^ inhabitance_proof id quants cases ^ + (* Eq proof *) + ".\n\n" ^ string_of_eqtype_proof is_recursive (cant_do_equality quants cases) id quants + +let render_extra_clause params = + "|" ^ string_of_list_prefix " " ", " (fun _ -> "_") params ^ " => default_val" + +let render_inh_param inhib_type_vars param = + match param.it with + | TypP id when List.mem id.it inhib_type_vars -> Some ("{_ : Inhabited " ^ render_id id.it ^ "}") + | _ -> None + +let render_single_type id at params = + let is_typ_param p = + match p.it with + | TypP _ -> true + | _ -> false + in + match List.rev params with + | {it = ExpP (_, typ); _} :: ps when List.for_all is_typ_param ps -> (render_type RHS typ, ps) + | _ -> error at ("Given projection function: " ^ id ^ " has invalid parameters!") + +let render_wfness_func_lemma id rule = + let RuleD (_, quants, _, _, prems) = rule.it in + let forall_quantifiers = string_of_list "forall " ",\n\t" " " (render_param RHS) quants in + let letprems, others = List.partition is_let prems in + let string_lets = string_of_list "" "" "\n\t" render_prem letprems in + let string_prems = string_of_list "" "" " ->\n\t" render_prem others in + "Lemma " ^ id ^ " : " ^ forall_quantifiers ^ string_lets ^ string_prems ^ ".\n" ^ + "Proof. Admitted" + +let render_function_def prefix id at params r_typ clauses = + let has_typ_fam = List.length params > 1 && List.exists is_type_family_param params in + let is_proj_func = StringSet.mem id !env_ref.proj_set in + let base_list_collector = base_collector [] (@) in + let c = { base_list_collector with collect_exp = needs_inh_class; collect_path = needs_inh_class_path } in + let inhabited_typ_vars = List.concat_map (fun clause -> + let DefD (_, _, exp, prems) = clause.it in + collect_exp c exp @ List.concat_map (collect_prem c) prems + ) clauses in + let extra_params = List.filter_map (render_inh_param inhabited_typ_vars) params in + let e_params_render = if extra_params = [] then "" else " " ^ String.concat " " extra_params in + prefix ^ id ^ render_params params ^ e_params_render ^ " : " ^ render_type RHS r_typ ^ " :=\n" ^ + "\tmatch " ^ render_match_quanters params ^ " return " ^ render_type RHS r_typ ^ " with\n\t\t" ^ + String.concat "\n\t\t" (List.map (fun clause -> match clause.it with + | DefD (_, args, exp, prems) -> + let (let_prems, others) = List.partition is_let prems in + assert (List.for_all (fun o -> o.it = ElsePr) others); + let string_of_let = string_of_list "\n\t\t\t" "\n\t\t\t" "\n\t\t\t" render_prem let_prems in + "|" ^ render_match_args args ^ " => " ^ string_of_let ^ render_exp RHS exp) clauses + ) ^ + (if has_typ_fam then "\n\t\t" ^ render_extra_clause params else "") ^ + "\n\tend" ^ + if is_proj_func + then + ".\n\n" ^ + render_coercion (render_single_type id at params) (render_type RHS r_typ) id + else "" + +let render_relation prefix id typ rules = + prefix ^ id ^ " : " ^ string_of_relation_args typ ^ "Prop :=\n\t" ^ + String.concat "\n\t" (List.map (fun rule -> match rule.it with + | RuleD (rule_id, quants, _, exp, prems) -> + let letprems, others = List.partition is_let prems in + let string_lets = string_of_list "\n\t\t" "" "\n\t\t" render_prem letprems in + let string_prems = string_of_list "\n\t\t" " ->\n\t\t" " ->\n\t\t" (render_prem) others in + let forall_quantifiers = string_of_list "forall " ", " " " (render_quant REL) quants in + "| " ^ render_id (rule_id.it) ^ " : " ^ forall_quantifiers ^ string_lets ^ string_prems ^ render_id id ^ " " ^ String.concat " " (List.map (render_exp REL) (transform_case_tup exp)) + ) rules) + +let render_axiom prefix id params r_typ = + prefix ^ id ^ " : " ^ string_of_list "forall " ", " " " (render_param RHS) params ^ render_type RHS r_typ + +let render_rel_axiom prefix id typ = + prefix ^ id ^ " : " ^ string_of_relation_args typ ^ "Prop" + +let render_global_declaration id typ exp = + "Definition " ^ id ^ " : " ^ render_type RHS typ ^ " := " ^ render_exp RHS exp + +let render_extra_info def = + match def.it with + | TypD (id, _, [{it = InstD (quants, _, {it = VariantT typcases; _}); _}]) -> + Some (inhabitance_proof id.it quants typcases ^ ".\n\n" ^ + string_of_eqtype_proof true (cant_do_equality quants typcases) id.it quants) + | _ -> None + +let has_prems c = + let only_otherwise_or_let prems = + match prems with + | [{it = ElsePr; _}] -> true + | prems when List.for_all is_let prems -> true + | _ -> false + in + match c.it with + | DefD (_, _, _, prems) -> prems <> [] && not (only_otherwise_or_let prems) + +let is_wf_lemma d = + match d.it with + | RelD (id, _, _, _, _) when StringSet.mem id.it !env_ref.wf_lemma_set -> + true + | _ -> false + +let start_prefix def = + match def.it with + | _ when is_wf_lemma def -> "" + | _ when is_inductive def -> "Inductive " + | DecD (_, _, _, []) -> "Axiom " + | DecD (_, _, _, clauses) when List.exists has_prems clauses -> "Axiom " + | DecD _ -> "Fixpoint " + | TypD (_, _, [inst]) when is_record_typ inst -> "Record " + | _ -> "" + +(* TODO - revise mutual recursion with other defs such as records and axioms *) +let rec string_of_def has_endline recursive def = + let end_newline = if has_endline then ".\n\n" else "" in + let start = if recursive then "" else comment_parens (comment_desc_def def ^ " at: " ^ Util.Source.string_of_region def.at) ^ "\n" in + match def.it with + | TypD (id, _, [{it = InstD (quants, _, {it = AliasT typ; _}); _}]) -> + if recursive then "" else + start ^ render_typealias (render_id id.it) quants typ ^ end_newline + | TypD (id, _, [{it = InstD (quants, _, {it = StructT typfields; _}); _}])-> + start ^ render_record recursive (render_id id.it) quants typfields ^ end_newline + | TypD (id, _, [{it = InstD (quants, _, {it = VariantT typcases; _}); _}]) -> + let prefix = if recursive then "" else "Inductive " in + start ^ render_variant_typ recursive prefix (render_id id.it) quants typcases ^ end_newline + | DecD (id, [], typ, [{it = DefD ([], [], exp, _); _}]) -> + start ^ render_global_declaration (render_id id.it) typ exp ^ end_newline + | DecD (id, params, typ, []) -> + let prefix = if recursive then "" else "Axiom " in + start ^ render_axiom prefix (render_id id.it) params typ ^ end_newline + | DecD (id, params, typ, clauses) when List.exists has_prems clauses -> + let prefix = if recursive then "" else "Axiom " in + start ^ render_axiom prefix (render_id id.it) params typ ^ end_newline + | DecD (id, params, typ, clauses) -> + let prefix = if recursive then "" else "Definition " in + start ^ render_function_def prefix (render_id id.it) id.at params typ (clauses) ^ end_newline + | RelD (id, _, _, typ, []) -> + let prefix = if recursive then "" else "Axiom " in + start ^ render_rel_axiom prefix (render_id id.it) typ ^ end_newline + | RelD (id, _, _, _, [rule]) when is_wf_lemma def -> + start ^ render_wfness_func_lemma id.it rule ^ end_newline + | RelD (id, _, _, typ, rules) -> + let prefix = if recursive then "" else "Inductive " in + start ^ render_relation prefix (render_id id.it) typ rules ^ end_newline + (* Mutual recursion - special handling for rocq *) + | RecD defs -> start ^ (match defs with + | [] -> "" + | _ when List.for_all is_wf_lemma defs -> + String.concat "" ( + List.map (string_of_def true true) defs + ) + | [d] -> + let extra_info = render_extra_info d in + start_prefix d ^ + string_of_def false true d ^ + begin match extra_info with + | None -> end_newline + | Some s -> end_newline ^ s ^ end_newline + end + | (d :: _) -> + let prefix = "\n\nwith\n\n" in + let extra_info = String.concat ".\n\n" (List.filter_map render_extra_info defs) in + start_prefix d ^ + String.concat prefix ( + List.map (string_of_def false true) defs + ) ^ ".\n\n" ^ + extra_info ^ if extra_info = "" then "" else end_newline + ) + | _ -> error def.at ("Unsupported def: " ^ Il.Print.string_of_def def) + +let exported_string = + "(* Imported Code *)\n" ^ + "From Coq Require Import String List Unicode.Utf8 Reals.\n" ^ + "From mathcomp Require Import all_ssreflect all_algebra.\n" ^ + "From HB Require Import structures.\n" ^ + "From RecordUpdate Require Import RecordSet.\n" ^ + "Declare Scope wasm_scope.\n\n" ^ + "Class Inhabited (T: Type) := { default_val : T }.\n\n" ^ + "Definition lookup_total {T: Type} {_: Inhabited T} (l: seq T) (n: nat) : T :=\n" ^ + "\tseq.nth default_val l n.\n\n" ^ + "Definition the {T : Type} {_ : Inhabited T} (arg : option T) : T :=\n" ^ + "\tmatch arg with\n" ^ + "\t\t| None => default_val\n" ^ + "\t\t| Some v => v\n" ^ + "\tend.\n\n" ^ + "Definition list_zipWith {X Y Z : Type} (f : X -> Y -> Z) (xs : seq X) (ys : seq Y) : seq Z :=\n" ^ + "\tseq.map (fun '(x, y) => f x y) (seq.zip xs ys).\n\n" ^ + "Definition option_zipWith {α β γ: Type} (f: α -> β -> γ) (x: option α) (y: option β): option γ := \n" ^ + "\tmatch x, y with\n" ^ + "\t\t| Some x, Some y => Some (f x y)\n" ^ + "\t\t| _, _ => None\n" ^ + "\tend.\n\n" ^ + "Fixpoint list_update {α: Type} (l: seq α) (n: nat) (y: α): seq α :=\n" ^ + "\tmatch l, n with\n" ^ + "\t\t| nil, _ => nil\n" ^ + "\t\t| x :: l', O => y :: l'\n" ^ + "\t\t| x :: l', S n => x :: list_update l' n y\n" ^ + "\tend.\n\n" ^ + "Definition option_append {α: Type} (x y: option α) : option α :=\n" ^ + "\tmatch x with\n" ^ + "\t\t| Some _ => x\n" ^ + "\t\t| None => y\n" ^ + "\tend.\n\n" ^ + "Definition option_map {α β : Type} (f : α -> β) (x : option α) : option β :=\n" ^ + "\tmatch x with\n" ^ + "\t\t| Some x => Some (f x)\n" ^ + "\t\t| _ => None\n" ^ + "\tend.\n\n" ^ + "Fixpoint list_update_func {α: Type} (l: seq α) (n: nat) (y: α -> α): seq α :=\n" ^ + "\tmatch l, n with\n" ^ + "\t\t| nil, _ => nil\n" ^ + "\t\t| x :: l', O => (y x) :: l'\n" ^ + "\t\t| x :: l', S n => x :: list_update_func l' n y\n" ^ + "\tend.\n\n" ^ + "Fixpoint list_slice {α: Type} (l: seq α) (i: nat) (j: nat): seq α :=\n" ^ + "\tmatch l, i, j with\n" ^ + "\t\t| nil, _, _ => nil\n" ^ + "\t\t| x :: l', O, O => nil\n" ^ + "\t\t| x :: l', S n, O => nil\n" ^ + "\t\t| x :: l', O, S m => x :: list_slice l' 0 m\n" ^ + "\t\t| x :: l', S n, m => list_slice l' n m\n" ^ + "\tend.\n\n" ^ + "Fixpoint list_slice_update {α: Type} (l: seq α) (i: nat) (j: nat) (update_l: seq α): seq α :=\n" ^ + "\tmatch l, i, j, update_l with\n" ^ + "\t\t| nil, _, _, _ => nil\n" ^ + "\t\t| l', _, _, nil => l'\n" ^ + "\t\t| x :: l', O, O, _ => nil\n" ^ + "\t\t| x :: l', S n, O, _ => nil\n" ^ + "\t\t| x :: l', O, S m, y :: u_l' => y :: list_slice_update l' 0 m u_l'\n" ^ + "\t\t| x :: l', S n, m, _ => x :: list_slice_update l' n m update_l\n" ^ + "\tend.\n\n" ^ + "Definition list_extend {α: Type} (l: seq α) (y: α): seq α :=\n" ^ + "\ty :: l.\n\n" ^ + "Definition option_map3 {A B C D: Type} (f: A -> B -> C -> D) (x: option A) (y: option B) (z: option C): option D :=\n" ^ + "\tmatch x, y, z with\n" ^ + "\t\t| Some x, Some y, Some z => Some (f x y z)\n" ^ + "\t\t| _, _, _ => None\n" ^ + "\tend.\n\n" ^ + "Definition list_map3 {A B C D: Type} (f : A -> B -> C -> D) (xs : seq A) (ys : seq B) (zs : seq C) : seq D :=\n" ^ + "\tseq.map (fun '(x, (y, z)) => f x y z) (seq.zip xs (seq.zip ys zs)).\n\n" ^ + "Inductive List_Forall3 {A B C: Type} (R : A -> B -> C -> Prop): seq A -> seq B -> seq C -> Prop :=\n" ^ + "\t| Forall3_nil : List_Forall3 R nil nil nil\n" ^ + "\t| Forall3_cons : forall x y z l l' l'',\n"^ + "\t\tR x y z -> List_Forall3 R l l' l'' -> List_Forall3 R (x :: l) (y :: l') (z :: l'').\n\n" ^ + "Inductive Foralli_help {X : Type} (f : nat -> X -> Prop) : nat -> list X -> Prop :=\n" ^ + "\t| Foralli_nil : forall n, Foralli_help f n nil\n" ^ + "\t| Foralli_cons : forall x l n,\n" ^ + "\tf n x -> Foralli_help f (n + 1) l -> Foralli_help f n (x::l).\n\n" ^ + "Definition List_Foralli {X : Type} (f : nat -> X -> Prop) (xs : list X) : Prop :=\n" ^ + "\tForalli_help f 0 xs.\n\n" ^ + "Definition holds_upto (P : nat -> Prop) (n : nat) :=\n" ^ + "\tForall P (iota 0 n).\n\n" ^ + "Class Append (α: Type) := _append : α -> α -> α.\n\n" ^ + "Infix \"@@\" := _append (right associativity, at level 60) : wasm_scope.\n\n" ^ + "Global Instance Append_List_ {α: Type}: Append (seq α) := { _append l1 l2 := seq.cat l1 l2 }.\n\n" ^ + "Global Instance Append_Option {α: Type}: Append (option α) := { _append o1 o2 := option_append o1 o2 }.\n\n" ^ + "Global Instance Append_nat : Append (nat) := { _append n1 n2 := n1 + n2}.\n\n" ^ + "Global Instance Inh_unit : Inhabited unit := { default_val := tt }.\n\n" ^ + "Global Instance Inh_nat : Inhabited nat := { default_val := O }.\n\n" ^ + "Global Instance Inh_list {T: Type} : Inhabited (seq T) := { default_val := nil }.\n\n" ^ + "Global Instance Inh_option {T: Type} : Inhabited (option T) := { default_val := None }.\n\n" ^ + "Global Instance Inh_int : Inhabited int := { default_val := 0 }.\n\n" ^ + "Global Instance Inh_rat : Inhabited rat := { default_val := 0 }.\n\n" ^ + "Global Instance Inh_prod {T1 T2: Type} {_: Inhabited T1} {_: Inhabited T2} : Inhabited (prod T1 T2) := { default_val := (default_val, default_val) }.\n\n" ^ + "Global Instance Inh_type : Inhabited Type := { default_val := nat }.\n\n" ^ + "Definition option_to_list {T: Type} (arg : option T) : seq T :=\n" ^ + "\tmatch arg with\n" ^ + "\t\t| None => nil\n" ^ + "\t\t| Some a => a :: nil\n" ^ + "\tend.\n\n" ^ + "Coercion option_to_list: option >-> seq.\n\n" ^ + "Definition int_to_nat (i : int) : nat :=\n" ^ + "\tmatch i with\n" ^ + "\t\t| Posz n => n\n" ^ + "\t\t| Negz n => 0\n" ^ + "\tend.\n\n" ^ + "Definition rat_to_int (r : rat) : int :=\n" ^ + "\t((numq r) %/ (denq r))%Z.\n\n" ^ + "Definition rat_to_nat (r : rat) : nat :=\n" ^ + "\tint_to_nat (rat_to_int r).\n\n" ^ + + "Coercion int_to_nat : int >-> nat.\n\n" ^ + "Coercion ratz : int >-> rat.\n\n" ^ + "Coercion rat_to_int : rat >-> int.\n\n" ^ + "Coercion rat_to_nat : rat >-> nat.\n\n" ^ + "Create HintDb eq_dec_db.\n\n" ^ + "Ltac decidable_equality_step :=\n" ^ + " do [ by eauto with eq_dec_db | decide equality ].\n\n" ^ + "Lemma eq_dec_Equality_axiom :\n" ^ + " forall (T : Type) (eq_dec : forall (x y : T), decidable (x = y)),\n" ^ + " let eqb v1 v2 := is_left (eq_dec v1 v2) in Equality.axiom eqb.\n" ^ + "Proof.\n" ^ + " move=> T eq_dec eqb x y. rewrite /eqb.\n" ^ + " case: (eq_dec x y); by [apply: ReflectT | apply: ReflectF].\n" ^ + "Qed.\n\n" ^ + "Class Coercion (A B : Type) := { coerce : A -> B }.\n\n" ^ + "Notation \"x ':>' B\" := (coerce (A:=_) (B:=B) x)\n" ^ + "(at level 70, right associativity).\n\n" ^ + "Definition option_coerce {A B : Type} `{Coercion A B} (a_opt : option A): option B :=\n" ^ + "\tmatch a_opt with\n" ^ + "\t\t| Some a => Some (coerce a)\n" ^ + "\t\t| None => None\n" ^ + "\tend.\n\n" ^ + "Definition list_coerce {A B : Type} `{Coercion A B} (a_list : seq A): seq B :=\n" ^ + "\t[seq (coerce a) | a <- a_list].\n\n" ^ + "Definition id_coerce {A : Type} (a : A) : A := a.\n\n" ^ + "Definition transitive_coerce {A B C : Type} `{Coercion A B} `{Coercion B C} (a : A): C :=\n" ^ + "\tcoerce (coerce a).\n\n" ^ + "Definition total_coerce {A B: Type} `{Coercion A (option B)} {_ : Inhabited B} (a : A): B :=\n" ^ + "\tthe (coerce a).\n\n" ^ + "Global Instance option_coercion (A B : Type) {_: Coercion A B}: Coercion (option A) (option B) := { coerce := option_coerce }.\n\n" ^ + "Global Instance list_coercion (A B : Type) {_: Coercion A B}: Coercion (seq A) (seq B) := { coerce := list_coerce }.\n\n" ^ + "Global Instance id_coercion (A : Type): Coercion A A := { coerce := id_coerce }.\n\n" ^ + "Global Instance transitive_coercion (A B C : Type) `{Coercion A B} `{Coercion B C}: Coercion A C := { coerce := transitive_coerce }.\n\n" ^ + "Global Instance total_coercion (A B : Type) `{Coercion A (option B)} {_ : Inhabited B}: Coercion A B := { coerce := total_coerce}.\n\n" ^ + "Notation \"| x |\" := (seq.size x) (at level 60).\n" ^ + "Notation \"!( x )\" := (the x) (at level 60).\n" ^ + "Notation \"x '[|' a '|]'\" := (lookup_total x a) (at level 10).\n" ^ + "Open Scope wasm_scope.\n" ^ + "Import ListNotations.\n" ^ + "Import RecordSetNotations.\n\n" + +let rec filter_def def = + match def.it with + | GramD _ | HintD _ -> None + | RecD defs -> Some {def with it = RecD (List.filter_map filter_def defs) } + | _ -> Some def + +let is_tf_hint h = h.hintid.it = Middlend.Typefamilyremoval.type_family_hint_id +let is_proj_hint h = h.hintid.it = Middlend.Uncaseremoval.uncase_proj_hint_id +let is_wf_hint h = h.hintid.it = Middlend.Undep.wf_hint_id +let is_wf_func_hint h = h.hintid.it = Middlend.Undep.wf_func_id +let is_wf_rel_hint h = h.hintid.it = Middlend.Undep.wf_rel_id + +let rec register_hints env def = + match def.it with + | HintD { it = TypH (id, hints); _} when List.exists is_tf_hint hints -> + env.tf_set <- StringSet.add id.it env.tf_set + | HintD { it = DecH (id, hints); _} when List.exists is_proj_hint hints -> + env.proj_set <- StringSet.add id.it env.proj_set + | HintD { it = RelH (id, hints); _} when List.exists is_wf_func_hint hints -> + env.wf_lemma_set <- StringSet.add id.it env.wf_lemma_set + | HintD { it = RelH (id, hints); _} when List.exists is_wf_rel_hint hints -> + env.wf_lemma_set <- StringSet.add id.it env.wf_lemma_set + | HintD { it = RelH (rel_id, hints); _} when List.exists is_wf_hint hints -> + begin match (List.find_opt is_wf_hint hints) with + | Some {hintexp = { it = El.Ast.VarE (typ_id, _); _}; _} -> + env.typ_to_wf_map <- StringMap.add typ_id.it rel_id.it env.typ_to_wf_map + | _ -> () + end + | RecD defs -> List.iter (register_hints env) defs + | _ -> () + +let string_of_script (il : script) = + !env_ref.il_env <- Il.Env.env_of_script il; + List.iter (register_hints !env_ref) il; + let il' = Disamb.transform il in + exported_string ^ + "(* Generated Code *)\n" ^ + String.concat "" (List.filter_map filter_def il' |> List.map (string_of_def true false)) \ No newline at end of file diff --git a/spectec/src/dune b/spectec/src/dune index aea839fdf3..6f4893d4f5 100644 --- a/spectec/src/dune +++ b/spectec/src/dune @@ -12,6 +12,7 @@ (re_export backend_prose) (re_export backend_splice) (re_export backend_interpreter) + (re_export backend_rocq) (re_export il2al) ) ) diff --git a/spectec/src/exe-spectec/main.ml b/spectec/src/exe-spectec/main.ml index 246a5f9e1c..e42b91e175 100644 --- a/spectec/src/exe-spectec/main.ml +++ b/spectec/src/exe-spectec/main.ml @@ -13,6 +13,7 @@ type target = | Prose of bool | Splice of Backend_splice.Config.t | Interpreter of string list + | Rocq type pass = | Sub @@ -22,13 +23,17 @@ type pass = | TypeFamilyRemoval | Else | Undep + | DefToRel | SubExpansion | Uncaseremoval | AliasDemut | ImproveIds | Ite + | PatSimp | ElseSimp | LetIntroMech + | DatatypeDiet + | SinglePatternMatch (* This list declares the intended order of passes. @@ -46,11 +51,15 @@ let all_passes = [ Else; ElseSimp; Uncaseremoval; - Sideconditions; SubExpansion; + PatSimp; Sub; + DefToRel; + Sideconditions; AliasDemut; - ImproveIds + ImproveIds; + DatatypeDiet; + SinglePatternMatch ] type file_kind = @@ -112,12 +121,17 @@ let pass_flag = function | AliasDemut -> "alias-demut" | Else -> "else" | Undep -> "remove-indexed-types" + | DefToRel -> "definition-to-relation" | SubExpansion -> "sub-expansion" | Uncaseremoval -> "uncase-removal" | ImproveIds -> "improve-ids" | Ite -> "ite" + | PatSimp -> "pattern-simp" | ElseSimp -> "else-simplification" | LetIntroMech -> "let-intro-mech" + | DatatypeDiet -> "datatype-diet" + | SinglePatternMatch -> "single-pattern-match" + let pass_desc = function | Sub -> "Synthesize explicit subtype coercions" @@ -127,13 +141,17 @@ let pass_desc = function | TypeFamilyRemoval -> "Transform Type families into sum types" | Else -> "Eliminate the otherwise premise in relations" | Undep -> "Transform indexed types into types with well-formedness predicates" + | DefToRel -> "Transform specific function definitions into relations" | SubExpansion -> "Expands subtype matching" | Uncaseremoval -> "Eliminate the uncase expression" | AliasDemut -> "Lifts type aliases out of mutual groups" | ImproveIds -> "Disambiguates ids used from each other" | Ite -> "If-then-else introduction" + | PatSimp -> "Simplifies non-linear and definite iteration patterns" | ElseSimp -> "Simplifies generated otherwise relations (after else pass)" | LetIntroMech -> "Let Premise introduction for mechanization backends" + | DatatypeDiet -> "Remove datatypes with over 50 constructors" + | SinglePatternMatch -> "Remove functions that pattern-match on several arguments" let run_pass : pass -> Il.Ast.script -> Il.Ast.script = function @@ -144,13 +162,28 @@ let run_pass : pass -> Il.Ast.script -> Il.Ast.script = function | TypeFamilyRemoval -> Middlend.Typefamilyremoval.transform | Else -> Middlend.Else.transform | Undep -> Middlend.Undep.transform + | DefToRel -> Middlend.Deftorel.transform | SubExpansion -> Middlend.Subexpansion.transform | Uncaseremoval -> Middlend.Uncaseremoval.transform | AliasDemut -> Middlend.AliasDemut.transform | ImproveIds -> Middlend.Improveids.transform | Ite -> Middlend.Ite.transform + | PatSimp -> Middlend.PatSimp.transform | LetIntroMech -> Middlend.Letintromech.transform | ElseSimp -> Middlend.Elsesimp.transform + | DatatypeDiet -> Middlend.Datatypediet.transform + | SinglePatternMatch -> Middlend.Singlepatternmatch.transform + + +(* Argument parsing - Specific for undep pass *) +let set_wf_state s = + Middlend.Undep.wf_state := + match s with + | "minimal" -> Middlend.Undep.WfMinimal + | "all" -> Middlend.Undep.WfAll + | "none" -> Middlend.Undep.WfNone + | _ -> + raise (Arg.Bad "wf-state must be minimal, all, or none") (* Argument parsing *) @@ -204,6 +237,7 @@ let argspec = Arg.align ( "--prose-rst", Arg.Unit (fun () -> target := Prose false), " Generate prose"; "--interpreter", Arg.Rest_all (fun args -> target := Interpreter args), " Generate interpreter"; + "--rocq", Arg.Unit (fun () -> target := Rocq), " Generate Rocq Inductive Definitions"; "--debug", Arg.Unit (fun () -> Backend_interpreter.Debugger.debug := true), " Debug interpreter"; "--unified-vars", Arg.Unit (fun () -> Il2al.Unify.rename := false), @@ -224,7 +258,11 @@ let argspec = Arg.align ( "--all-passes", Arg.Unit (fun () -> List.iter enable_pass all_passes)," Run all passes"; "--test-version", Arg.Int (fun i -> Backend_interpreter.Construct.version := i; Il2al.Translate.version := i), " Wasm version to assume for tests (default: 3)"; - + "--wf-state", Arg.String set_wf_state, " Denotes the placement of wfness relations for the remove-indexed-types pass + (default: minimal): + minimal: Places wfness premises for terms that do not appear in the conclusion + all: Places wfness premises whenever it encounters a term that needs it + none: Does not place any wfness premises"; "-help", Arg.Unit ignore, ""; "--help", Arg.Unit ignore, ""; ] ) @@ -254,6 +292,22 @@ let () = (match !target with | Prose _ | Splice _ | Interpreter _ -> enable_pass Sideconditions; + | Rocq -> + enable_pass Sideconditions; + enable_pass Totalize; + enable_pass Else; + enable_pass TypeFamilyRemoval; + enable_pass Undep; + enable_pass Uncaseremoval; + enable_pass Sub; + enable_pass SubExpansion; + enable_pass ImproveIds; + enable_pass AliasDemut; + enable_pass DefToRel; + enable_pass Ite; + enable_pass ElseSimp; + enable_pass PatSimp; + enable_pass LetIntroMech | _ when !print_al || !print_al_o <> "" -> enable_pass Sideconditions; | _ -> () @@ -280,7 +334,7 @@ let () = if !print_final_il && not !print_all_il then print_il il; let al = - if not !print_al && !print_al_o = "" && (!target = Check || !target = Ast || !target = Latex) then [] + if not !print_al && !print_al_o = "" && (!target = Check || !target = Ast || !target = Latex || !target = Rocq) then [] else ( log "Translating to AL..."; let interp = match !target with @@ -390,6 +444,19 @@ let () = Backend_interpreter.Ds.init al; log "Interpreting..."; Backend_interpreter.Runner.run args + | Rocq -> + log "Rocq Generation..."; + (match !odsts with + | [] -> print_endline (Backend_rocq.Print.string_of_script il) + | [odst] -> + let coq_code = Backend_rocq.Print.string_of_script il in + let oc = Out_channel.open_text odst in + Fun.protect (fun () -> Out_channel.output_string oc coq_code) + ~finally:(fun () -> Out_channel.close oc) + | _ -> + prerr_endline "too many output file names"; + exit 2 + ) ); log "Complete." with diff --git a/spectec/src/il/dune b/spectec/src/il/dune index 2cb4bc8a45..e2631a27cd 100644 --- a/spectec/src/il/dune +++ b/spectec/src/il/dune @@ -1,5 +1,5 @@ (library (name il) (libraries util zarith xl el) - (modules ast eq free fresh subst iter walk env eval print debug valid) + (modules ast eq free fresh subst iter walk env eval print debug valid hints) ) diff --git a/spectec/src/il/hints.ml b/spectec/src/il/hints.ml new file mode 100644 index 0000000000..ba19628ce3 --- /dev/null +++ b/spectec/src/il/hints.ml @@ -0,0 +1,50 @@ +open Ast +open Util.Source + +(* Types for mode hint *) +type mode = In | Out +type side = L | R +module IntMap = Map.Make(Int) +module StringMap = Map.Make(String) + +type t = { + mutable modes : mode IntMap.t StringMap.t +} + +let empty = { + modes = StringMap.empty +} + +let find_opt = StringMap.find_opt + +let parse_mode err : El.Ast.exp -> mode IntMap.t = + let rec go side (exp: El.Ast.exp) mm = match exp.it with + | HoleE (`Num i) -> if side = L then IntMap.add i In mm else IntMap.add i Out mm + | VarE (b, []) when b.it = "bool" -> mm + | ParenE e -> go side e mm + | TupE es | SeqE es -> List.fold_left (fun acc e -> go side e acc) mm es + | _ -> mm + in + fun exp -> match exp.it with + | InfixE (lhs, atom, rhs) when atom.it = Xl.Atom.Arrow -> + let lm = go L lhs IntMap.empty in + let rm = go R rhs lm in + rm + | _ -> err exp.at ("Ill-formed mode hint: " ^ El.Print.string_of_exp exp) + +let build_il_hints err (il : script) : t = + let hints = List.filter_map (fun d -> match d.it with + | HintD hintdef -> Some hintdef + | _ -> None + ) il in + List.fold_left (fun hintenv hdef -> + match hdef.it with + | RelH (rid, hints) -> + List.fold_left (fun hintenv' hint -> + match hint.hintid.it with + | "mode" -> + { modes = StringMap.add rid.it (parse_mode err hint.hintexp) hintenv'.modes } + | _ -> hintenv' + ) hintenv hints + | _ -> hintenv + ) empty hints \ No newline at end of file diff --git a/spectec/src/il/iter.ml b/spectec/src/il/iter.ml index e20f4eff19..26868810d9 100644 --- a/spectec/src/il/iter.ml +++ b/spectec/src/il/iter.ml @@ -19,6 +19,7 @@ sig val visit_typ : typ -> unit val visit_deftyp : deftyp -> unit val visit_exp : exp -> unit + val visit_arg : arg -> unit val visit_path : path -> unit val visit_sym : sym -> unit val visit_prem : prem -> unit @@ -46,6 +47,7 @@ struct let visit_typ _ = () let visit_deftyp _ = () let visit_exp _ = () + let visit_arg _ = () let visit_path _ = () let visit_sym _ = () let visit_prem _ = () @@ -219,6 +221,7 @@ and prems prs = list prem prs (* Definitions *) and arg a = + visit_arg a; match a.it with | ExpA e -> exp e | TypA t -> typ t @@ -268,4 +271,4 @@ let rec def d = | GramD (x, ps, t, prods) -> gramid x; params ps; typ t; list prod prods | RecD ds -> list def ds | HintD hd -> hintdef hd -end +end \ No newline at end of file diff --git a/spectec/src/il/walk.ml b/spectec/src/il/walk.ml index 0cdc1091ac..5c648bd296 100644 --- a/spectec/src/il/walk.ml +++ b/spectec/src/il/walk.ml @@ -35,7 +35,8 @@ type transformer = { transform_def_id: id -> id; transform_gram_id: id -> id; - filter_exp : exp -> exp option + (* Adjusting traversal *) + transform_types_of_exp : bool } let id = Fun.id @@ -55,7 +56,7 @@ let base_transformer = { transform_def_id = id; transform_gram_id = id; - filter_exp = op_id + transform_types_of_exp = true } let rec transform_typ t typ = @@ -72,7 +73,6 @@ let rec transform_typ t typ = and transform_exp t e = let f = t.transform_exp in - let g = t.filter_exp in let t_exp = transform_exp t in let it = match e.it with @@ -107,13 +107,8 @@ and transform_exp t e = | SubE (e1, _t1, t2) -> SubE (t_exp e1, _t1, t2) | IfE (e1, e2, e3) -> IfE (t_exp e1, t_exp e2, t_exp e3) in - - let e' = - match g {e with it; note = transform_typ t e.note } with - | Some e' -> f e' - | None -> e - in - f e' + let typ' = if t.transform_types_of_exp then transform_typ t e.note else e.note in + f { e with it; note = typ' } and transform_iter t iter = match iter with @@ -226,6 +221,8 @@ type 'a collector = { default: 'a; compose: 'a -> 'a -> 'a; collect_exp: exp -> 'a * bool; + collect_path: path -> 'a * bool; + collect_quant: quant -> 'a * bool; collect_prem: prem -> 'a * bool; collect_iterexp: iterexp -> 'a * bool; collect_typ: typ -> 'a * bool; @@ -238,6 +235,8 @@ let base_collector default compose = { default = default; compose = compose; collect_exp = no_collect default; + collect_path = no_collect default; + collect_quant = no_collect default; collect_prem = no_collect default; collect_iterexp = no_collect default; collect_typ = no_collect default; @@ -301,11 +300,16 @@ and collect_iterexp c iterexp = and collect_path c p = let ( $@ ) = c.compose in - match p.it with - | RootP -> c.default - | DotP (p', _) -> collect_path c p' - | IdxP (p', e) -> collect_path c p' $@ collect_exp c e - | SliceP (p', e1, e2) -> collect_path c p' $@ collect_exp c e1 $@ collect_exp c e2 + let f = c.collect_path in + let traverse_list = + match p.it with + | RootP -> c.default + | DotP (p', _) -> collect_path c p' + | IdxP (p', e) -> collect_path c p' $@ collect_exp c e + | SliceP (p', e1, e2) -> collect_path c p' $@ collect_exp c e1 $@ collect_exp c e2 + in + let (res, continue) = f p in + res $@ if continue then traverse_list else c.default and collect_arg c a = let f = c.collect_arg in @@ -342,6 +346,13 @@ and collect_param c p = | DefP (_, params, typ) -> compose_list c (collect_param c) params $@ collect_typ c typ | GramP (_, params, typ) -> compose_list c (collect_param c) params $@ collect_typ c typ +and collect_quant c q = + let ( $@ ) = c.compose in + let f = c.collect_quant in + let traverse_list = collect_param c q in + let (res, continue) = f q in + res $@ if continue then traverse_list else c.default + and collect_sym c s = let ( $@ ) = c.compose in match s.it with diff --git a/spectec/src/middlend/datatypediet.ml b/spectec/src/middlend/datatypediet.ml new file mode 100644 index 0000000000..a02c63b9ce --- /dev/null +++ b/spectec/src/middlend/datatypediet.ml @@ -0,0 +1,316 @@ +(* + +This transformation aims to produce an AST where no datatype has more than *50* constructors. + +This is because some proof assistants, like Isabelle, struggle to process datatypes with many constructors. In Isabelle, compiling a datatype is quadratic in the number of constructors, and 50 constructors already takes several seconds. + +Instead, when a datatype has more than 50 constructors, we redefine the grammar with several layers, e.g. + +mydatatype = +| Case0 of args0 +| Case1 of args1 +| Case2 of args2 +. +. +. +| Case99 of args99 + +becomes + +mydatatype = +| Mydatatype_subcase_0 of mydatatype_subtype_0 +| Mydatatype_subcase_1 of mydatatype_subtype_1 +| Mydatatype_subcase_2 of mydatatype_subtype_2 +. +. +. +| Mydatatype_subcase_10 of mydataype_subtype_10 + +where + +mydatatype_subtype_0 = +| Case0 of args0 +| Case1 of args1 +| Case2 of args2 +. +. +. +| Case9 of args9 + +and + +mydatatype_subtype_1 = +| Case10 of args10 +| Case11 of args11 +| Case12 of args12 +. +. +. +| Case19 of args19 + +etc. + +We then need to replace all occurences of constructor `Case37 args` with `Mydatatype_subcase_3 (Expanded_case37 args)`, etc. + +For optimality, when breaking up a datatype with a number N>50 of constructors, we make sqrt(N) cases. If sqrt(N) is greater than 50 we repeat the operation recursively. + +Recursion: if mydatatype is recursive, we group all non-recursive cases first and make a minimal recursive definition in the end. + + *) + + +let max_cases = 50 + +open Il.Ast +open Util.Source +open Xl.Mixop + +module StringMap = Map.Make(String) +module MixopMap = Map.Make(struct type t = unit mixop let compare = compare end) + + +let get_fathertype id sontype = + match sontype.it with + | VarT (_, args) -> { sontype with it = VarT (id $ no_region, args) } + | _ -> failwith "should be variant type" + + +let find_new_constructors acc t = + match t.it with + | VarT (id, _) -> StringMap.find_opt id.it acc + | _ -> None + + +let rec transform_exp acc exp = + let f e = { exp with it = e } in + let te = transform_exp acc in + match exp.it with + | VarE _ (* TODO: can VarE be a type constructor? *) + | BoolE _ | NumE _ | TextE _ | OptE None -> exp + | UnE (u, o, exp) -> f (UnE (u, o, te exp)) + | BinE (b, o, e1, e2) -> f (BinE (b, o, te e1, te e2)) + | CmpE (c, o, e1, e2) -> f (CmpE (c, o, te e1, te e2)) + | TupE es -> f (TupE (List.map te es)) + | ProjE (e, i) -> f (ProjE (te e, i)) + | CaseE (id, e) -> + begin match find_new_constructors acc exp.note with + | Some acc -> + let fathername, fathertypeid = MixopMap.find id acc in + let fathertype = get_fathertype fathertypeid exp.note in + f (CaseE (fathername, + { it = CaseE (id, te e) ; at = exp.at ; note = fathertype })) + | None -> f (CaseE (id, te e)) end + | UncaseE _ -> failwith "Uncase should have been removed" + | OptE (Some e) -> f (OptE (Some (te e))) + | TheE e -> f (TheE (te e)) + | StrE fields -> f (StrE (List.map (fun (field, e) -> (field, te e)) fields)) + | DotE (e, field) -> f (DotE (te e, field)) + | CompE (e1, e2) -> f (CompE (te e1, te e2)) + | ListE es -> f (ListE (List.map te es)) + | LiftE e -> f (LiftE (te e)) + | MemE (e1, e2) -> f (MemE (te e1, te e2)) + | LenE e -> f (LenE (te e)) + | CatE (e1, e2) -> f (CatE (te e1, te e2)) + | IdxE (e1, e2) -> f (IdxE (te e1, te e2)) + | SliceE (e1, e2, e3) -> f (SliceE (te e1, te e2, te e3)) + | UpdE (e1, p, e2) -> f (UpdE (te e1, transform_path acc p, te e2)) + | ExtE (e1, p, e2) -> f (ExtE (te e1, transform_path acc p, te e2)) + | IfE (e1, e2, e3) -> f (IfE (te e1, te e2, te e3)) + | CallE (id, args) -> f (CallE (id, List.map (transform_arg acc) args)) + | IterE (e, itexp) -> f (IterE (te e, transform_iterexp acc itexp)) + | CvtE (e, t1, t2) -> f (CvtE (te e, t1, t2)) + | SubE (e, t1, t2) -> f (SubE (te e, t1, t2)) + +and transform_arg acc arg = + match arg.it with + | ExpA e -> { arg with it = ExpA (transform_exp acc e) } + | TypA _ | DefA _ -> arg + | GramA sym -> { arg with it = GramA (transform_sym acc sym) } + +and transform_iterexp acc (it, exps) = + (it, List.map (fun (id, exp) -> (id, transform_exp acc exp)) exps) + +and transform_sym acc sym = + match sym.it with + | VarG (id, args) -> { sym with it = VarG (id, List.map (transform_arg acc) args) } + | NumG _ | TextG _ | EpsG -> sym + | SeqG syms -> { sym with it = SeqG (List.map (transform_sym acc) syms) } + | AltG syms -> { sym with it = AltG (List.map (transform_sym acc) syms) } + | RangeG (sym1, sym2) -> { sym with it = RangeG (transform_sym acc sym1, transform_sym acc sym2) } + | IterG (sym1, itexp) -> { sym with it = IterG (transform_sym acc sym1, transform_iterexp acc itexp) } + | AttrG (exp, sym1) -> { sym with it = AttrG (transform_exp acc exp, transform_sym acc sym1) } + +and transform_path acc path = + match path.it with + | RootP -> path + | IdxP (p,e) -> { path with it = IdxP (transform_path acc p, transform_exp acc e) } + | SliceP (p, e1, e2) -> { path with it = SliceP (transform_path acc p, transform_exp acc e1, transform_exp acc e2) } + | DotP (p, a) -> { path with it = DotP (transform_path acc p, a) } + + + +let rec transform_prem acc prem = + match prem.it with + | RulePr (id, args, op, exp) -> {prem with it = RulePr (id, List.map (transform_arg acc) args, op, transform_exp acc exp)} + | IfPr exp -> {prem with it = IfPr (transform_exp acc exp)} + | LetPr (ss, exp1, exp2) -> {prem with it = LetPr (ss, transform_exp acc exp1, transform_exp acc exp2)} + | ElsePr -> prem + | IterPr (prem', itexp) -> {prem with it = IterPr (transform_prem acc prem', transform_iterexp acc itexp)} + | NegPr prem' -> {prem with it = NegPr (transform_prem acc prem')} + +let transform_rule acc rule = + match rule.it with + | RuleD (id, quants, op, exp, prems) -> {rule with it = RuleD (id, quants, op, transform_exp acc exp, List.map (transform_prem acc) prems)} + +let transform_clause acc clause = + match clause.it with + | DefD (quants, args, exp, prems) -> {clause with it = DefD (quants, List.map (transform_arg acc) args, transform_exp acc exp, List.map (transform_prem acc) prems)} + +let transform_prod acc prod = + match prod.it with + | ProdD (quants, sym, exp, prems) -> { prod with it = ProdD (quants, transform_sym acc sym, transform_exp acc exp, List.map (transform_prem acc) prems)} + +let sqrt_int n = + int_of_float (sqrt (float_of_int n)) + +let rec is_recursive_type ids t = + match t.it with + | VarT (id, args) -> List.mem id.it ids || List.exists (is_recursive_arg ids) args + | BoolT | NumT _ | TextT -> false + | TupT ts -> List.exists (fun (_, t) -> is_recursive_type ids t) ts + | IterT (t, _) -> is_recursive_type ids t +and is_recursive_arg ids arg = + match arg.it with + | ExpA _e -> false (* TODO: technically e could contain a type *) + | TypA t -> is_recursive_type ids t + | DefA _ -> false + | GramA _sym -> false (* TODO: technically sym could contain a type *) + + +let is_recursive ids typecase = + match typecase with + | (_, (t, _,_), _) -> + is_recursive_type ids t + +let split_constructor id l1 quants l2 typecases ids at1 at2 at3 = + let n = List.length typecases in + let nb_cases, max_constr_per_case, resplit = + if max_cases * max_cases < n then + if (n / max_cases) * max_cases < n then + n / max_cases + 1, max_cases, true + else n / max_cases, max_cases, true + else let m = sqrt_int n in + if m * m < n then + if m * (m + 1) < n then + m + 1, m + 1, false + else m, m + 1, false + else m, m, false in + let yes_rec, non_rec = List.partition (is_recursive ids) typecases in + let rec aux acc done_cases nexti current_case current_case_count typecases = + if current_case_count = max_constr_per_case then + aux acc ((nexti, current_case) :: done_cases) (nexti + 1) [] 0 typecases + else + match typecases with + | [] -> acc, done_cases, nexti, current_case, current_case_count + | (casename, typ, hints) :: q -> + let fathername = + Seq [ Atom { it = Xl.Atom.Atom (id.it ^ "_subcase_" ^ string_of_int nexti) ; + at = no_region ; + note = Xl.Atom.info "automatically generated subcase during datatype dieting" } ; + Arg () ] in + aux (MixopMap.add casename (fathername, id.it ^ "_subtype_" ^ string_of_int nexti) acc) + done_cases nexti + ((casename, typ, hints) :: current_case) + (current_case_count + 1) q in + let acc, non_recs, nexti, current_case, current_case_count = + aux MixopMap.empty [] 0 [] 0 non_rec in + let acc, yes_recs, nexti, current_case, current_case_count = + aux acc [] nexti current_case current_case_count yes_rec in + let yes_recs, nb_cases' = + if current_case = [] then yes_recs, nexti else yes_recs @ [nexti, current_case], nexti + 1 in + if nexti * max_constr_per_case + current_case_count = n && nb_cases' = nb_cases then () + else failwith "arithmetic error"; + let non_recs = List.map (fun (i, typecases) -> + { it = TypD (id.it ^ "_subtype_" ^ string_of_int i $ no_region, l1, [ { it = InstD (quants, l2, { it = VariantT typecases ; at = at1 ; note = ()}) ; + at = at2 ; note = () } ]) ; at = at3 ; note = () }) non_recs in + let yes_recs = List.map (fun (i, typecases) -> + { it = TypD (id.it ^ "_subtype_" ^ string_of_int i $ no_region, l1, [ { it = InstD (quants, l2, { it = VariantT typecases ; at = at1 ; note = ()}) ; + at = at2 ; note = () } ]) ; at = at3 ; note = () }) yes_recs in + let main_typecases = List.init nb_cases + (fun i -> (Seq [Atom { it = Xl.Atom.Atom (id.it ^ "_subcase_" ^ string_of_int i) ; + at = no_region; + note = Xl.Atom.info "automatically generated subcase during datatype dieting" }; + Arg ()], + ((VarT (id.it ^ "_subtype_" ^ string_of_int i $ no_region, [])) $ no_region, [], []), [])) in (* TODO: subtype may expect args *) + let main_case = + { it = TypD (id, l1, [ + { it = InstD (quants, l2, + { it = VariantT main_typecases; + at = at1 ; note = () }) ; at = at2 ; note = () } ]) ; at = at3 ; note = () } in + let epilog = [] (* TODO: want to define fun def so only need to replace in pattern matching? *) in + + non_recs, main_case :: yes_recs, epilog, acc, if resplit then [(id, l1, quants, l2, main_typecases, at1, at2, at3)] else [] + + +let get_constructors def = + match def.it with + | TypD (id, l1, [{ it = InstD (quants, l2, { it = VariantT typecases ; at = at1 ; _ }) ; at = at2 ; _ }]) -> Some (id, l1, quants, l2, typecases, at1, at2, def.at) + | TypD (_, _, { it = InstD (_, _, {it = VariantT _ ; _}) ; _} :: _) -> failwith "ill-formed datatype definition" + | TypD _ -> None + | _ -> failwith "should be a type definition" + +let get_some = function + | Some x -> x + | None -> failwith "non-datatype defined mutually recursively with a datatype" + + + +let transform_typ_defs acc def (* original definition, in case no change is needed *) defs = + let constructors = List.map get_constructors defs in + if List.for_all (function None -> true | _ -> false) constructors then acc, [def] else + let constructors = List.map get_some constructors in + if List.for_all (fun (_,_,_,_,l,_,_,_) -> List.length l <= max_cases) constructors then acc, [def] else + let ids = List.map (fun (id, _,_,_,_,_,_,_) -> id.it) constructors in + let rec aux acc = function + | [] -> [], [], [], acc + | (id, l1, quants, l2, typecases, at1, at2, at3) :: q when List.length typecases <= max_cases -> + let prelude, mutrec, epilog, acc = aux acc q in + prelude, { it = TypD (id, l1, [ { it = InstD (quants, l2, { it = VariantT typecases ; at = at1 ; note = ()}) ; + at = at2 ; note = () } ]) ; at = at3 ; note = () } :: mutrec, epilog, acc + | (id, l1, quants, l2, typecases, at1, at2, at3) :: q -> + let prelude', mutrec', epilog', acc', resplit = split_constructor id l1 quants l2 typecases ids at1 at2 at3 in + let prelude, mutrec, epilog, acc = aux acc (resplit @ q) in + prelude' @ prelude, mutrec' @ mutrec, epilog' @ epilog, + StringMap.add id.it acc' acc in + let prelude, mutrec, epilog, acc = aux acc constructors in + let mutrec = match mutrec with + | [def] -> def + | _ -> { it = RecD mutrec ; at = def.at ; note = () } in + acc, prelude @ [mutrec] @ epilog + + + + + +let rec transform_def acc def = + match def.it with + | TypD _ -> transform_typ_defs acc def [def] + | RelD (id, params, op, t, rules) -> acc, [{def with it = RelD (id, params, op, t, List.map (transform_rule acc) rules)}] + | DecD (id, params, t, clauses) -> acc, [{def with it = DecD (id, params, t, List.map (transform_clause acc) clauses)}] + | GramD (id, params, t, prods) -> acc, [{def with it = GramD (id, params, t, List.map (transform_prod acc) prods)}] + | RecD defs -> + (match defs with + | { it = TypD _ ; _ } :: _ -> transform_typ_defs acc def defs + | _ -> let acc, defs = List.fold_left (fun (acc, defs) def -> + let acc, defs' = transform_def acc def in + acc, defs' @ defs) (acc, []) defs in + acc, [{def with it = RecD (List.rev defs)}]) + | HintD _ -> acc, [def] + + + +let transform script = + let (_, defs) = List.fold_left (fun (acc, defs) def -> + let (acc, def) = transform_def acc def in + acc, def :: defs) (StringMap.empty, []) script in + List.flatten (List.rev defs) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml new file mode 100644 index 0000000000..0b58daacf3 --- /dev/null +++ b/spectec/src/middlend/deftorel.ml @@ -0,0 +1,695 @@ +open Il.Ast +open Il +open Il.Walk +open Util.Source +open Util + +module StringSet = Set.Make(String) + +module ExpMap = Map.Make(struct + type t = exp + let compare exp1 exp2 = if Eq.eq_exp exp1 exp2 then 0 + (* HACK - Need better way to compare exps, only hurts performance *) + else String.compare (Print.string_of_exp exp1) (Print.string_of_exp exp2) +end) + +type env = { + mutable il_env : Il.Env.t; + mutable rel_set : StringSet.t; + mutable def_arg_set : StringSet.t; + mutable rec_funcs : StringSet.t +} + +let empty_env = { + il_env = Il.Env.empty; + rel_set = StringSet.empty; + def_arg_set = StringSet.empty; + rec_funcs = StringSet.empty +} + +let fun_prefix = "fun_" + +let force_func_hint_id = "recfunc" + +let has_rec_hint hint = hint.hintid.it = force_func_hint_id + +let apply_iter_to_var id iter = + match iter with + | Opt -> id ^ Il.Print.string_of_iter Opt + | _ -> id ^ Il.Print.string_of_iter List + + +let get_exp_arg a = + match a.it with + | ExpA exp -> exp + | _ -> assert false + +let transform_typ_iter i = + match i with + | ListN _ -> + (* Definite iterators not allowed in types *) + List + | _ -> i + +let filter_iter_quants args iter_quants = + let check_iter free_set iter = + match iter with + | ListN (_, Some id) -> Free.Set.mem id.it free_set + | _ -> false + in + let free_vars = (Free.free_list Free.free_arg args).varid in + (List.fold_left (fun (free_set, acc) (iter, id_exp_pairs) -> + let has_definite_iter = check_iter free_set iter in + + let new_id_exp_pairs = List.filter (fun (id, _) -> + Free.Set.mem id.it free_set + ) id_exp_pairs in + + (* Must preserve iteration if the iteration variable (i.e. i) is used, + * EVEN if the list itself is not being used. + *) + let new_id_exp_pairs' = if has_definite_iter then id_exp_pairs else + new_id_exp_pairs + in + + if new_id_exp_pairs' = [] && (not has_definite_iter) then (free_set, acc) else + let iter_vars = List.fold_left (fun acc (_, e) -> + Free.Set.union acc (Free.free_exp e).varid + ) Free.Set.empty new_id_exp_pairs' in + let new_set = Free.Set.union iter_vars free_set in + (new_set, (iter, new_id_exp_pairs') :: acc) + ) (free_vars, []) iter_quants) + |> snd |> List.rev + +let rec create_collector iterexps env = + let base_collector_iters = base_collector [] (@) in + { base_collector_iters with collect_exp = collect_fcalls_exp iterexps env; collect_prem = collect_fcalls_prem iterexps env } + +and collect_fcalls_exp iterexps env e = + match e.it with + | CallE (id, args) when StringSet.mem id.it env.rel_set -> + let new_iter_quants = filter_iter_quants args iterexps in + ([((fun_prefix ^ id.it $ id.at, args, e.note), new_iter_quants, List.length new_iter_quants)], true) + | IterE (e1, iterexp) -> + let c1 = create_collector iterexps env in + let c2 = create_collector (iterexp :: iterexps) env in + (collect_exp c2 e1 @ collect_iterexp c1 iterexp, false) + | _ -> ([], true) + +and collect_fcalls_prem iterexps env p = + match p.it with + | IterPr (p', iterexp) -> + let c1 = create_collector iterexps env in + let c2 = create_collector (iterexp :: iterexps) env in + (collect_prem c2 p' @ collect_iterexp c1 iterexp, false) + | _ -> ([], true) + +let create_fun_prem ids ((id, args, r_typ), iterexps, _) = + let fresh_var = Utils.generate_var ids "" in + let var_exp = VarE (fresh_var $ id.at) $$ id.at % r_typ in + let new_mixop = Xl.Mixop.(Seq (List.init (List.length args + 1) (fun _ -> Arg ()))) in + let exps = List.map get_exp_arg args in + let r_typ_tup = ("_" $ id.at, r_typ) in + let tupt = TupT (List.map (fun e -> "_" $ id.at, e.note) exps @ [r_typ_tup]) $ id.at in + let tupe = TupE (exps @ [var_exp]) $$ id.at % tupt in + let rule_prem = RulePr (id, [], new_mixop, tupe) $ id.at in + let new_var, typ, prem = List.fold_left (fun (var, typ, prem) (iter, id_exp_pairs) -> + let new_typ = IterT (typ, transform_typ_iter iter) $ id.at in + let new_var = apply_iter_to_var var iter in + let var_exp = VarE (new_var $ id.at) $$ id.at % new_typ in + let new_id_exp_pairs = (var $ id.at, var_exp) :: id_exp_pairs in + (new_var, new_typ, IterPr (prem, (iter, new_id_exp_pairs)) $ id.at) + ) (fresh_var, r_typ, rule_prem) iterexps in + fresh_var, ExpP (new_var $ id.at, typ) $ id.at, prem + +let create_call_map fcalls quants = + let fcalls' = Util.Lib.List.nub (fun ((id, args, _), iterexps, _) ((id', args', _), iterexps', _) -> + Eq.eq_id id id' && + Eq.eq_list Eq.eq_arg args args' && + Eq.eq_list Eq.eq_iterexp iterexps iterexps' + ) fcalls in + let ids = List.map Utils.get_param_id quants |> List.map it in + let ids', new_quants, new_prems = List.fold_left (fun acc fcall -> + let ids', quants', prems = acc in + let new_var, bind, prem = create_fun_prem (ids @ ids') fcall in + new_var :: ids', bind :: quants', prem :: prems + ) ([], [], []) fcalls' + in + let call_map = List.fold_left2 (fun map var_id ((fun_id, args, typ), _, iter_num) -> + let var_exp = VarE (var_id $ fun_id.at) $$ fun_id.at % typ in + let call_exp = CallE (fun_id, args) $$ fun_id.at % typ in + ExpMap.add call_exp (var_exp, iter_num) map + ) ExpMap.empty (List.rev ids') fcalls' + in + call_map, new_quants, new_prems + +let rec transform_iter call_map env i = + match i with + | ListN (exp, id_opt) -> ListN (fst (transform_exp call_map env exp), id_opt) + | _ -> i + +and transform_typ call_map env t = + let it, iter_ids = (match t.it with + | VarT (id, args) -> + let args', iter_ids_list = List.split (List.map (transform_arg call_map env) args) in + VarT (id, args'), List.concat iter_ids_list + | TupT exp_typ_pairs -> + let pairs, iter_ids_list = List.split (List.map (fun (id, t) -> + let t', iter_ids2 = transform_typ call_map env t in + (id, t'), iter_ids2) exp_typ_pairs) in + TupT pairs, List.concat iter_ids_list + | IterT (typ, iter) -> + let typ', iter_ids = transform_typ call_map env typ in + IterT (typ', transform_iter call_map env iter), iter_ids + | typ -> typ, [] + ) in + {t with it}, iter_ids + +and transform_typ_normal call_map env t = fst (transform_typ call_map env t) +and transform_exp call_map env e: (exp * (id * typ * int) list) = + let t_func = transform_exp call_map env in + let it, iter_ids = (match e.it with + | CaseE (m, e1) -> + let e1', iter_ids = t_func e1 in + CaseE (m, e1'), iter_ids + | StrE fields -> + let fields', iter_ids = List.split (List.map (fun (a, e1) -> + let e1', iter_ids = t_func e1 in + (a, e1'), iter_ids) fields) in + StrE fields', List.concat iter_ids + | UnE (unop, optyp, e1) -> + let e1', iter_ids = t_func e1 in + UnE (unop, optyp, e1'), iter_ids + | BinE (binop, optyp, e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + BinE (binop, optyp, e1', e2'), iter_ids @ iter_ids2 + | CmpE (cmpop, optyp, e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + CmpE (cmpop, optyp, e1', e2'), iter_ids @ iter_ids2 + | TupE (exps) -> + let exps', iters_ids = List.split (List.map t_func exps) in + TupE exps', List.concat iters_ids + | ProjE (e1, n) -> + let e1', iter_ids = t_func e1 in + ProjE (e1', n), iter_ids + | UncaseE (e1, m) -> + let e1', iter_ids = t_func e1 in + UncaseE (e1', m), iter_ids + | OptE (Some e1) -> + let e1', iter_ids = t_func e1 in + OptE (Some e1'), iter_ids + | TheE e1 -> + let e1', iter_ids = t_func e1 in + TheE e1', iter_ids + | DotE (e1, a) -> + let e1', iter_ids = t_func e1 in + DotE (e1', a), iter_ids + | CompE (e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + CompE (e1', e2'), iter_ids @ iter_ids2 + | ListE exps -> + let exps', iters_ids = List.split (List.map t_func exps) in + ListE exps', List.concat iters_ids + | LiftE e1 -> + let e1', iter_ids = t_func e1 in + LiftE e1', iter_ids + | MemE (e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + MemE (e1', e2'), iter_ids @ iter_ids2 + | LenE e1 -> + let e1', iter_ids = t_func e1 in + LenE e1', iter_ids + | CatE (e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + CatE (e1', e2'), iter_ids @ iter_ids2 + | IdxE (e1, e2) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + IdxE (e1', e2'), iter_ids @ iter_ids2 + | SliceE (e1, e2, e3) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + let e3', iter_ids3 = t_func e3 in + SliceE (e1', e2', e3'), iter_ids @ iter_ids2 @ iter_ids3 + | UpdE (e1, p, e2) -> + let e1', iter_ids = t_func e1 in + let p', iter_ids2 = transform_path call_map env p in + let e2', iter_ids3 = t_func e2 in + UpdE (e1', p', e2'), iter_ids @ iter_ids2 @ iter_ids3 + | ExtE (e1, p, e2) -> + let e1', iter_ids = t_func e1 in + let p', iter_ids2 = transform_path call_map env p in + let e2', iter_ids3 = t_func e2 in + ExtE (e1', p', e2'), iter_ids @ iter_ids2 @ iter_ids3 + | CallE (id, args) -> + let e' = {e with it = CallE (fun_prefix ^ id.it $ id.at, args)} in + begin match (ExpMap.find_opt e' call_map) with + | Some (e', 0) -> e'.it, [] + | Some ({it = VarE id; note; _} as e', n) -> e'.it, [(id, note, n - 1)] + | _ -> + let args', iter_ids_list = List.split (List.map (transform_arg call_map env) args) in + CallE (id, args'), List.concat iter_ids_list + end + | IterE (e1, (iter, id_exp_pairs)) -> + let e1', iter_ids = t_func e1 in + let free_vars = (Free.free_exp e1').varid in + let new_id_exp_pairs = List.map (fun (id, typ, _) -> + let itert = IterT (typ, transform_typ_iter iter) $ typ.at in + (id, VarE (apply_iter_to_var id.it iter $ id.at) $$ id.at % itert) + ) iter_ids in + let new_iter_ids = List.filter_map (fun (id, typ, num) -> + if num = 0 then None else + let itert = IterT (typ, transform_typ_iter iter) $ typ.at in + Some (apply_iter_to_var id.it iter $ id.at, itert, num - 1) + ) iter_ids in + let id_exp_pairs_filtered, more_iter_ids = List.split (List.filter_map (fun (id, iter_e) -> + if not (Free.Set.mem id.it free_vars) then None else + let iter_e', iter_ids = t_func iter_e in + Some ((id, iter_e'), iter_ids) + ) id_exp_pairs) + in + IterE (e1', (transform_iter call_map env iter, new_id_exp_pairs @ id_exp_pairs_filtered)), + new_iter_ids @ List.concat more_iter_ids + | CvtE (e1, nt1, nt2) -> + let e1', iter_ids = t_func e1 in + CvtE (e1', nt1, nt2), iter_ids + | SubE (e1, t1, t2) -> + let e1', iter_ids = t_func e1 in + let t1', iter_ids2 = transform_typ call_map env t1 in + let t2', iter_ids3 = transform_typ call_map env t2 in + SubE (e1', t1', t2'), iter_ids @ iter_ids2 @ iter_ids3 + | IfE (e1, e2, e3) -> + let e1', iter_ids = t_func e1 in + let e2', iter_ids2 = t_func e2 in + let e3', iter_ids3 = t_func e3 in + IfE (e1', e2', e3'), iter_ids @ iter_ids2 @ iter_ids3 + | exp -> exp, []) in + {e with it}, iter_ids + +and transform_path call_map env path = + let it, iter_ids = (match path.it with + | RootP -> RootP, [] + | IdxP (p, e1) -> + let p', iter_ids = transform_path call_map env p in + let e1', iter_ids2 = transform_exp call_map env e1 in + IdxP (p', e1'), iter_ids @ iter_ids2 + | SliceP (p, e1, e2) -> + let p', iter_ids = transform_path call_map env p in + let e1', iter_ids2 = transform_exp call_map env e1 in + let e2', iter_ids3 = transform_exp call_map env e2 in + SliceP (p', e1', e2'), iter_ids @ iter_ids2 @ iter_ids3 + | DotP (p, a) -> + let p', iter_ids = transform_path call_map env p in + DotP (p', a), iter_ids + ) in + {path with it}, iter_ids + +and transform_exp_normal call_map env e = fst (transform_exp call_map env e) + +and transform_sym call_map env s = + let it, iter_ids = (match s.it with + | VarG (id, args) -> + let args', iter_ids_list = List.split (List.map (transform_arg call_map env) args) in + VarG (id, args'), List.concat iter_ids_list + | SeqG syms -> + let syms', iter_ids_list = List.split (List.map (transform_sym call_map env) syms) in + SeqG syms', List.concat iter_ids_list + | AltG syms -> + let syms', iter_ids_list = List.split (List.map (transform_sym call_map env) syms) in + AltG syms', List.concat iter_ids_list + | RangeG (syml, symu) -> + let syml', iter_ids = transform_sym call_map env syml in + let symu', iter_ids2 = transform_sym call_map env symu in + RangeG (syml', symu'), iter_ids @ iter_ids2 + | IterG (sym, (iter, id_exp_pairs)) -> + let sym', iter_ids = transform_sym call_map env sym in + IterG (sym', (transform_iter call_map env iter, + List.map (fun (id, exp) -> (id, fst (transform_exp call_map env exp))) id_exp_pairs) + ), iter_ids + | AttrG (e, sym) -> + let e', iter_ids = transform_exp call_map env e in + let sym', iter_ids2 = transform_sym call_map env sym in + AttrG (e', sym'), iter_ids @ iter_ids2 + | sym -> sym, [] + ) in + {s with it}, iter_ids + +and transform_arg call_map env a: arg * (id * typ * int) list = + let it, iter_ids = (match a.it with + | ExpA exp -> + let exp', iter_ids = transform_exp call_map env exp in + ExpA exp', iter_ids + | TypA typ -> + let typ', iter_ids = transform_typ call_map env typ in + TypA typ', iter_ids + | DefA id -> DefA id, [] + | GramA sym -> + let sym', iter_ids = transform_sym call_map env sym in + GramA sym', iter_ids + ) in + {a with it}, iter_ids + +and transform_param call_map env p = + (match p.it with + | ExpP (id, typ) -> ExpP (id, transform_typ_normal call_map env typ) + | TypP id -> TypP id + | DefP (id, params, typ) -> DefP (id, List.map (transform_param call_map env) params, transform_typ_normal call_map env typ) + | GramP (id, quants, typ) -> GramP (id, List.map (transform_param call_map env) quants, transform_typ_normal call_map env typ) + ) $ p.at + +let rec transform_prem call_map env prem = + let it, iter_ids = match prem.it with + | RulePr (id, qs, m, e) -> + let e', iter_ids = transform_exp call_map env e in + RulePr (id, qs, m, e'), iter_ids + | IfPr e -> + let e', iter_ids = transform_exp call_map env e in + IfPr e', iter_ids + | LetPr (ids, e1, e2) -> + (* TODO - properly handle this if it actually gets used *) + let e1', iter_ids = transform_exp call_map env e1 in + let e2', iter_ids2 = transform_exp call_map env e2 in + LetPr (ids, e1', e2'), iter_ids @ iter_ids2 + | ElsePr -> ElsePr, [] + | IterPr (prem1, (iter, id_exp_pairs)) -> + let prem1', iter_ids = transform_prem call_map env prem1 in + let free_vars = (Free.free_prem prem1').varid in + let new_id_exp_pairs = List.map (fun (id, typ, _) -> + let itert = IterT (typ, transform_typ_iter iter) $ typ.at in + (id, VarE (apply_iter_to_var id.it iter $ id.at) $$ id.at % itert) + ) iter_ids in + let new_iter_ids = List.filter_map (fun (id, typ, num) -> + if num = 0 then None else + let itert = IterT (typ, transform_typ_iter iter) $ typ.at in + Some (apply_iter_to_var id.it iter $ id.at, itert, num - 1) + ) iter_ids in + let id_exp_pairs_filtered, more_iter_ids = List.split (List.filter_map (fun (id, iter_e) -> + if not (Free.Set.mem id.it free_vars) then None else + let iter_e' , iter_ids = transform_exp call_map env iter_e in + Some ((id, iter_e'), iter_ids) + ) id_exp_pairs) in + IterPr (prem1', (transform_iter call_map env iter, new_id_exp_pairs @ id_exp_pairs_filtered)), + new_iter_ids @ List.concat more_iter_ids + | NegPr p -> + let p', iter_ids = transform_prem call_map env p in + NegPr p', iter_ids + in + {prem with it}, iter_ids + +and transform_prem_normal call_map env prem = fst (transform_prem call_map env prem) + +let transform_rule env rule = + (match rule.it with + | RuleD (id, quants, m, exp, prems) -> + let c = create_collector [] env in + let fcalls = collect_exp c exp @ List.concat_map (collect_prem c) prems in + let call_map, new_quants, new_prems = create_call_map fcalls quants in + RuleD (id.it $ no_region, + List.map (transform_param call_map env) (quants @ new_quants), + m, + transform_exp_normal call_map env exp, + List.map (transform_prem_normal call_map env) (new_prems @ prems)) + ) $ rule.at + +let transform_clause env clause = + (match clause.it with + | DefD (quants, args, exp, prems) -> + let c = create_collector [] env in + let fcalls = collect_exp c exp @ List.concat_map (collect_prem c) prems in + let call_map, new_quants, new_prems = create_call_map fcalls quants in + DefD ( + List.map (transform_param call_map env) (quants @ new_quants), + args, + transform_exp_normal call_map env exp, + List.map (transform_prem_normal call_map env) (prems @ new_prems)) + ) $ clause.at + +let transform_prod env prod = + match prod.it with + | ProdD (quants, sym, exp, prems) -> + let c = create_collector [] env in + let fcalls = collect_exp c exp @ List.concat_map (collect_prem c) prems in + let call_map, new_quants, new_prems = create_call_map fcalls quants in + ProdD (List.map (transform_param call_map env) (quants @ new_quants), + sym, + transform_exp_normal call_map env exp, + List.map (transform_prem_normal call_map env) (new_prems @ prems)) $ prod.at + +let is_exp_param param = + match param.it with + | ExpP _ -> true + | _ -> false + +let utilizes_rel_def env e = + match e.it with + | CallE (id, _) -> (StringSet.mem id.it env.rel_set, true) + | _ -> (false, true) + +let collect_list_length_vars () : StringSet.t ref * (module Iter.Arg) = + let module Arg = + struct + include Iter.Skip + let acc = ref StringSet.empty + let visit_exp exp = + match exp.it with + | IterE (_, (ListN ({it = VarE id; _}, _), [_])) -> + acc := StringSet.add id.it !acc + | _ -> () + end + in Arg.acc, (module Arg) + +let must_be_relation env id params clauses = + let is_let p = + match p.it with + | LetPr _ -> true + | _ -> false + in + let only_otherwise_or_let prems = + match prems with + | [{it = ElsePr; _}] -> true + | prems when List.for_all is_let prems -> true + | _ -> false + in + let listn_set, (module Arg : Iter.Arg) = collect_list_length_vars () in + let rel_def_checker = { exists_base_checker with collect_exp = utilizes_rel_def env} in + assert (!listn_set = StringSet.empty); + let module Acc = Iter.Make(Arg) in + (* Current limitation of relations - can only have standard types. + No type parameters or higher order functions *) + List.for_all is_exp_param params && + (* Limitation - functions used as def ids cannot be relations *) + not (StringSet.mem id.it env.def_arg_set) && + List.exists (fun c -> match c.it with + | DefD (quants, args, exp, prems) -> + Acc.args args; + (* Premises might not be decidable *) + (* NOTE: if its only otherwise premise, then fall-through semantics should be + able to handle it. Also with let, if there are only let premises then this is + allowed. + *) + (prems <> [] && not (only_otherwise_or_let prems)) || + (* Functions that have function calls transformed to relations must also be relations *) + collect_exp rel_def_checker exp || + List.exists (collect_prem rel_def_checker) prems || + (* Checking if equality binding is active *) + fst (List.fold_left (fun (acc_bool, free_set) arg -> + let free_vars = Free.free_arg arg in + (acc_bool || Free.inter free_vars free_set <> Free.empty, Free.union free_vars free_set) + ) (false, Free.empty) args) || + (* There are more binded variables than utilized in the arguments *) + let bounded_vars = Free.free_list Free.bound_quant quants in + let free_vars = Free.free_list Free.free_arg args in + Free.diff bounded_vars free_vars <> Free.empty || + (* HACK - dealing with list of a specified length with relations instead of functions *) + !listn_set <> StringSet.empty + ) clauses + +let get_tuple_exp e = + match e.it with + | TupE exps -> exps + | _ -> [e] + +let tail_mixop mixop = + match mixop with + | Xl.Mixop.Seq xs -> Xl.Mixop.Seq (List.tl xs) + | _ -> mixop + +(* + This function filters out premises that were function calls before. It only filters them out if they are + not being used in any premise that it not the one that is being checked. + This avoids the problem with violating strictly positive condition for inductive relations when the recursive + function call appears in the return expression. This does not however prevent the violation of the condition + completely, as any recursive function call that appears as a pattern guard will violate this (as long as the + fallthrough semantics is enforced). +*) +let rec filter_return_prems all_prems prems = + let pred p ps = + match p.it with + | RulePr (id, _, _, {it = TupE exps; _}) when String.starts_with ~prefix:fun_prefix id.it -> + let ps' = Lib.List.filter_not (fun p' -> Eq.eq_prem p p') ps in + let last_exp = Lib.List.last_opt exps in + begin match last_exp with + | None -> true + | Some exp -> + let free_vars = (Free.free_exp exp).varid in + let free_vars_prems = (Free.free_list Free.free_prem ps').varid in + Free.Set.inter free_vars free_vars_prems <> Free.Set.empty + end + | _ -> true + in + match prems with + | [] -> [] + | p :: ps when pred p all_prems -> p :: filter_return_prems all_prems ps + | _ :: ps -> filter_return_prems all_prems ps + +let generate_matching_rules env args tupt r = + match r.it with + | RuleD (id, quants, mixop, exp', prems) -> + let (args', _) = Lib.List.split_last (get_tuple_exp exp') in + let new_exp = TupE args' $$ exp'.at % tupt in + (try Eval.match_list Eval.match_exp env.il_env Subst.empty args' args with Eval.Irred -> None) |> + Option.map (fun _ -> + {r with it = RuleD (id, quants, tail_mixop mixop, new_exp, filter_return_prems prems prems)} + ) + +let is_otherwise prem = + match prem.it with + | ElsePr -> true + | _ -> false + +let fall_through_prems env id mixop typs rules = + let gen_rel_name rid = + id.it ^ "_before_" ^ rid.it $ id.at + in + let rec go prev_rules = function + | [] -> [ RelD (id, [], mixop, TupT typs $ id.at, List.rev prev_rules) $ id.at ] + | ({it = RuleD (rid, quants, m, exp, prems); _} as r) :: rs when List.exists is_otherwise prems -> + let (args, _) = Lib.List.split_last (get_tuple_exp exp) in + let (typs', _) = Lib.List.split_last typs in + let tupt = TupT typs' $ id.at in + let rules' = + List.filter_map (generate_matching_rules env args tupt) prev_rules + in + let prems' = List.filter (fun p -> p.it <> ElsePr) prems in + if rules' = [] then go ({ r with it = RuleD (rid, quants, m, exp, prems') } :: prev_rules) rs else + let relation = RelD (gen_rel_name rid, [], tail_mixop mixop, tupt, rules') $ id.at in + let negrulepr = NegPr (RulePr (gen_rel_name rid, [], tail_mixop mixop, TupE args $$ exp.at % tupt) $ rid.at) $ rid.at in + let new_rule = { r with it = RuleD (rid, quants, m, exp, negrulepr :: prems') } in + relation :: go (new_rule :: prev_rules) rs + | r :: rs -> go (r :: prev_rules) rs + in + go [] rules + +let cvt_let_to_if prems = + let quants, prems = List.map (fun p -> match p.it with + | LetPr (quants, e1, e2) -> + (quants, IfPr (CmpE (`EqOp, `BoolT, e1, e2) $$ e1.at % (BoolT $ e1.at)) $ p.at) + | _ -> ([], p) + ) prems |> List.split in + (List.concat quants, prems) + +let cvt_def_to_rel env id params r_typ clauses = + let get_param_typ p = + match p.it with + | ExpP (_, t) -> t + | _ -> assert false + in + let types = List.map get_param_typ params @ [r_typ] in + let tup_types = (List.map (fun t -> "_" $ id.at, t) types) in + let new_mixop = Xl.Mixop.(Seq (List.init (List.length params + 1) (fun _ -> Arg ()))) in + let rules = List.mapi (fun i clause -> + match clause.it with + | DefD (quants, args, exp, prems) -> + let new_quants, prems' = cvt_let_to_if prems in + let exps = List.map get_exp_arg args in + let c = create_collector [] env in + let fcalls = collect_exp c exp @ List.concat_map (collect_prem c) prems' in + let call_map, new_quants', new_prems = create_call_map fcalls new_quants in + let tupe = TupE (exps @ [transform_exp_normal call_map env exp]) $$ id.at % (TupT tup_types $ id.at) in + RuleD (fun_prefix ^ id.it ^ "_case_" ^ Int.to_string i $ id.at, quants @ new_quants @ new_quants', new_mixop, tupe, List.map (transform_prem_normal call_map env) (new_prems @ prems')) $ id.at + ) clauses + in + let new_id = { id with it = fun_prefix ^ id.it } in + fall_through_prems env new_id new_mixop tup_types rules + +let uses_def ids_set def = + match def.it with + | RelD (_, _, _, _, rules) -> + let free_defs = (Free.free_list (Free.free_rule) rules).relid in + Free.Set.inter free_defs ids_set <> Free.Set.empty + | _ -> false + +let rec transform_def (env : env) def = + (* let must_be_rel_def d = + match d.it with + | DecD (id, params, _, clauses) -> must_be_relation env id params clauses + | _ -> false + in *) + let has_exp_params d = + match d.it with + | DecD (_, params, _, _) -> List.for_all is_exp_param params + | _ -> false + in + (match def.it with + | RelD (id, qs, m, typ, rules) -> + [{ def with it =RelD (id, qs, m, typ, List.map (transform_rule env) rules) }] + | DecD (id, params, typ, clauses) when must_be_relation env id params clauses -> + env.rel_set <- StringSet.add id.it env.rel_set; + cvt_def_to_rel env id params typ clauses + | DecD (id, params, typ, clauses) -> + [{ def with it = DecD (id, params, typ, List.map (transform_clause env) clauses) }] + | RecD [{it = DecD (id, params, typ, clauses); at; _}] when + StringSet.mem id.it env.rec_funcs && not (must_be_relation env id params clauses) -> + let def' = DecD (id, params, typ, List.map (transform_clause env) clauses) $ at in + [{ def with it = RecD [def'] }] + | RecD defs when List.for_all has_exp_params defs -> + let ids_ref = ref StringSet.empty in + List.iter (fun d -> match d.it with + | DecD (id, _, _, _) -> + ids_ref := StringSet.add (fun_prefix ^ id.it) !ids_ref; + env.rel_set <- StringSet.add id.it env.rel_set + | _ -> () + ) defs; + let rec_defs, filtered_defs = defs |> + List.concat_map (transform_def env) |> + List.partition (uses_def !ids_ref) + in + filtered_defs @ [{ def with it = RecD rec_defs }] + | RecD defs -> [{ def with it = RecD (List.concat_map (transform_def env) defs) }] + | GramD (id, params, typ, prods) -> [{ def with it = GramD (id, params, typ, List.map (transform_prod env) prods) }] + | d -> [d $ def.at] + ) + +let collect_def_args (): StringSet.t ref * (module Iter.Arg) = + let module Arg = + struct + include Iter.Skip + let acc = ref StringSet.empty + let visit_arg arg = + match arg.it with + | DefA id -> acc := StringSet.add id.it !acc + | _ -> () + end + in Arg.acc, (module Arg) + +let create_rec_func_set env (d : def) = + match d.it with + | HintD {it = DecH (id, hints); _} when List.exists has_rec_hint hints -> + env.rec_funcs <- StringSet.add id.it env.rec_funcs + | _ -> () + + +let transform (il : script): script = + let env = empty_env in + env.il_env <- Il.Env.env_of_script il; + let acc, (module Arg : Iter.Arg) = collect_def_args () in + let module Acc = Iter.Make(Arg) in + List.iter Acc.def il; + List.iter (create_rec_func_set env) il; + env.def_arg_set <- !acc; + List.concat_map (transform_def env) il \ No newline at end of file diff --git a/spectec/src/middlend/deftorel.mli b/spectec/src/middlend/deftorel.mli new file mode 100644 index 0000000000..64d020ff9d --- /dev/null +++ b/spectec/src/middlend/deftorel.mli @@ -0,0 +1 @@ +val transform : Il.Ast.script -> Il.Ast.script \ No newline at end of file diff --git a/spectec/src/middlend/dune b/spectec/src/middlend/dune index a76bac5174..5227596f1a 100644 --- a/spectec/src/middlend/dune +++ b/spectec/src/middlend/dune @@ -10,12 +10,17 @@ else undep utils + deftorel subexpansion uncaseremoval aliasDemut improveids ite + patSimp + deftorel elsesimp letintromech + datatypediet + singlepatternmatch ) ) diff --git a/spectec/src/middlend/improveids.ml b/spectec/src/middlend/improveids.ml index 2f7a4552bc..3a9c117790 100644 --- a/spectec/src/middlend/improveids.ml +++ b/spectec/src/middlend/improveids.ml @@ -4,6 +4,7 @@ open Il.Walk open Util.Source (* open Util *) open Xl.Atom +open Xl module StringMap = Map.Make(String) module StringSet = Set.Make(String) @@ -19,19 +20,20 @@ let fun_prefix = "fun_" let res_prefix = "r_" type id_type = - | VAR (* Variables *) - | USERDEF (* Types, type constructors and relations *) - | FUNCDEF (* function definitions *) + | Var (* Variables *) + | Userdef (* Types and relations *) + | Funcdef (* function definitions *) + | Atoms (* Type constructors *) -let empty_info: region * Xl.Atom.info = (no_region, {def = ""; case = ""}) +let empty_info typ_id: region * Xl.Atom.info = (no_region, {def = typ_id; case = ""}) (* Id transformation *) -let rec transform_id' (env : env) (id_type : id_type) (s : text) = - let t_func = transform_id' env id_type in +let transform_id' (env : env) (id_type : id_type) (s : text) = let change_id s' = String.map (function | '.' -> '_' | '-' -> '_' + | '#' -> '_' | c -> c ) s' (* This suffixes any '*' with '_lst' and '?' with '_opt' for clarity *) @@ -42,24 +44,26 @@ let rec transform_id' (env : env) (id_type : id_type) (s : text) = match id_type with (* Leave naming hole as is *) | _ when s' = "_" -> s' - | VAR when Il.Env.mem_typ env.il_env (s' $ no_region) + | Var when Il.Env.mem_typ env.il_env (s' $ no_region) || Il.Env.mem_rel env.il_env (s' $ no_region) || Il.Env.mem_def env.il_env (s' $ no_region) - || StringSet.mem s' env.atom_str_set -> t_func (var_prefix ^ s') - | FUNCDEF when Il.Env.mem_typ env.il_env (s' $ no_region) + || StringSet.mem s' env.atom_str_set -> (var_prefix ^ s') + | Funcdef when Il.Env.mem_typ env.il_env (s' $ no_region) || Il.Env.mem_rel env.il_env (s' $ no_region) - || StringSet.mem s' env.atom_str_set -> t_func (fun_prefix ^ s') + || StringSet.mem s' env.atom_str_set -> (fun_prefix ^ s') + | Userdef when StringSet.mem s' env.atom_str_set -> (res_prefix ^ s') (* Checking whether an id is an int - if so, put a reserved prefix *) - | _ when Option.is_some (int_of_string_opt s') -> t_func (res_prefix ^ s') + | _ when Option.is_some (int_of_string_opt s') -> (res_prefix ^ s') | _ -> s' -let t_var_id env id = transform_id' env VAR id.it $ id.at -let t_def_id env id = transform_id' env FUNCDEF id.it $ id.at -let t_user_def_id env id = transform_id' env USERDEF id.it $ id.at +let t_var_id env id = transform_id' env Var id.it $ id.at +let t_def_id env id = transform_id' env Funcdef id.it $ id.at +let t_user_def_id env id = transform_id' env Userdef id.it $ id.at +let t_atom_id env id = transform_id' env Atoms id.it $ id.at let transform_rule_id env rule_id rel_id = match rule_id.it with | "" -> make_prefix ^ rel_id.it - | _ -> transform_id' env USERDEF rule_id.it + | _ -> transform_id' env Atoms rule_id.it let is_atomid a = match a.it with @@ -71,22 +75,37 @@ let has_atom_hole m = | [{it = Atom "_"; _}] -> true | _ -> false +let register_atom_id env s = + env.atom_str_set <- StringSet.add s env.atom_str_set + (* Atom functions *) let transform_atom env typ_id a = match a.it with - | Atom s -> Atom (t_user_def_id env (s $ a.at)).it $$ a.at % a.note - | _ -> Atom (make_prefix ^ typ_id) $$ a.at % a.note + | Atom s -> + register_atom_id env (t_atom_id env (s $ a.at)).it; + Atom (t_atom_id env (s $ a.at)).it $$ a.at % a.note + | _ -> + register_atom_id env (make_prefix ^ typ_id); + Atom (make_prefix ^ typ_id) $$ a.at % a.note + +(* Atom transformation where there might be other atom constructs, leave them be *) +let transform_atom' env a = + match a.it with + | Atom s -> + register_atom_id env (t_atom_id env (s $ a.at)).it; + Atom (t_atom_id env (s $ a.at)).it $$ a.at % a.note + | _ -> a let transform_mixop env typ_id (m : mixop) = -(* TODO! Not sure what the expected result is for this one. *) -ignore (env, typ_id, empty_info, is_atomid, has_atom_hole, transform_atom); m -(* - let m' = List.map (fun inner_m -> List.filter is_atomid inner_m) m in + let m' = List.map (fun inner_m -> List.filter is_atomid inner_m) (Mixop.flatten m) in let len = List.length m' in match m' with - | _ when List.for_all (fun l -> l = [] || has_atom_hole l) m' -> [(Atom (make_prefix ^ typ_id) $$ empty_info)] :: List.init (len - 1) (fun _ -> []) - | _ -> Xl.Mixop.map_atoms (transform_atom env typ_id)) m' -*) + | _ when List.for_all (fun l -> l = [] || has_atom_hole l) m' -> + register_atom_id env (make_prefix ^ typ_id); + let atom = Xl.Mixop.Atom (Atom (make_prefix ^ typ_id) $$ empty_info typ_id) in + Xl.Mixop.(Seq (atom :: List.init (len - 1) (fun _ -> Arg ()))) + | _ -> Xl.Mixop.map_atoms (transform_atom' env) m + let rec check_iteration_naming e iterexp = match e.it, iterexp with @@ -95,14 +114,6 @@ let rec check_iteration_naming e iterexp = Eq.eq_id id id' && check_iteration_naming e i | _ -> false -and t_typ env t = - (match t.it with - | VarT (id, []) when not (Env.mem_typ env.il_env id) -> - (* Type parameter - treat it as such *) - VarT (t_var_id env id, []) - | typ -> typ - ) $ t.at - and t_exp env e = (match e.it with | CaseE (m, e1) -> @@ -160,10 +171,31 @@ let transform_rule tf env rel_id rule = ) ) $ rule.at +let is_wf_hint hintid = hintid.it = Undep.wf_hint_id +let transform_el_exp env hintid e = + (match e.it with + | El.Ast.VarE (id, args) when is_wf_hint hintid -> El.Ast.VarE (t_user_def_id env id, args) + | e' -> e' + ) $ e.at + +let transform_hintdef env hintdef = + let t_hint h = + { h with hintexp = transform_el_exp env h.hintid h.hintexp} + in + let t_hints hs = List.map t_hint hs in + let h = match hintdef.it with + | TypH (id, hints) -> TypH (t_user_def_id env id, t_hints hints) + | RelH (id, hints) -> RelH (t_user_def_id env id, t_hints hints) + | DecH (id, hints) -> DecH (t_user_def_id env id, t_hints hints) + | GramH (id, hints) -> GramH (t_user_def_id env id, t_hints hints) + | RuleH (id, rid, hints) -> + RuleH (t_user_def_id env id, transform_rule_id env rid id $ rid.at, t_hints hints) + in + { hintdef with it = h } + let rec t_def env def = let tf = { base_transformer with transform_exp = t_exp env; - transform_typ = t_typ env; transform_path = t_path env; transform_var_id = t_var_id env; transform_typ_id = t_user_def_id env; @@ -173,25 +205,29 @@ let rec t_def env def = (match def.it with | TypD (id, params, insts) -> TypD (t_user_def_id env id, - List.map (transform_param tf) params |> Utils.improve_ids_params, + Utils.improve_ids_params params |> + List.map (transform_param tf), List.map (t_inst tf env id) insts) | RelD (id, params, m, typ, rules) -> RelD (t_user_def_id env id, - List.map (transform_param tf) params |> Utils.improve_ids_params, + Utils.improve_ids_params params |> + List.map (transform_param tf), m, transform_typ tf typ, List.map (transform_rule tf env id) rules) | DecD (id, params, typ, clauses) -> DecD (t_def_id env id, - List.map (transform_param tf) params |> Utils.improve_ids_params, + Utils.improve_ids_params params |> + List.map (transform_param tf), transform_typ tf typ, List.map (transform_clause tf) clauses) | GramD (id, params, typ, prods) -> GramD (id, - List.map (transform_param tf) params |> Utils.improve_ids_params, + Utils.improve_ids_params params |> + List.map (transform_param tf), transform_typ tf typ, List.map (transform_prod tf) prods) | RecD defs -> RecD (List.map (t_def env) defs) - | HintD hintdef -> HintD hintdef + | HintD hintdef -> HintD (transform_hintdef env hintdef) ) $ def.at let create_env il = { diff --git a/spectec/src/middlend/improveids.mli b/spectec/src/middlend/improveids.mli index eed6fb6d57..11c3257ea4 100644 --- a/spectec/src/middlend/improveids.mli +++ b/spectec/src/middlend/improveids.mli @@ -2,15 +2,30 @@ This pass simply ensures that there is no ambiguity between any names. It does this by creating a massive set of names, separated by the - different main constructs (i.e. TypD, RelD, DecD, etc.). + different namespaces (i.e. TypD, RelD, DecD, etc.). This is done using + the existing environment generator that the IL has. - It makes sure that variables don't have the same name as anything else, - as this could cause shadowing in some cases for ITPs. If it does have - the same name, then it adds the prefix "v_" until the name is unique. + It makes sure that variables don't have the same name as any other + namespace, as this could cause shadowing in some cases for ITPs. + If it does have the same name, then it adds the prefix + "v_". - For functions, we unsure that they don't have the same name as + For functions, we ensure that they don't have the same name as user-defined types and relations. If it does, then it adds the prefix - "fun_" until the name is unique. + "fun_". + + For user-defined types and relations, we make sure that they don't have + the same name as Atoms. If it does, then it adds the prefix "r_" + + Atoms are considered a namespace as well, and it is made sure that the + other namespaces don't clash with this one. However, no disambiguation + is made for Atoms of the same name. This is due to some ITPs having + already builtin mechanisms to handle this. + + NOTE: This is not a guaranteed name clash avoidance pass, as it has a very + naive renaming strategy. This will get revisited in the future + to ensure that this works for all cases + but for now it is sufficient. *) diff --git a/spectec/src/middlend/patSimp.ml b/spectec/src/middlend/patSimp.ml new file mode 100644 index 0000000000..cf9d0066a5 --- /dev/null +++ b/spectec/src/middlend/patSimp.ml @@ -0,0 +1,173 @@ +(* + This pass simplifies definite iteration and non-linear patterns + by utilizing premises. + + It achieves this through the following steps: + - For non-linear patterns: + * For each clause, we traverse the arguments and keep track + of all variables in expressions. If a variable appears more + than once, we generate a fresh version of the variable and + keep it for later. + * Once we have traversed the entire argument list, we use + the variables tracked to generate new quantifiers and equality + premises. + - For definite iteration: + * For each clause, we traverse the arguments, and collect + all variables used for definite iteration (i.e. the e in ListN e _ ) + and the respective lists being iterated. + * Using the collected variables, we iterate through the list to create + the equality premises. + + + For example (for non-linear pattern), take the function: + + def $find(nat, nat* ) : bool + def $find(n, eps ) = false + def $find(n, n n'* ) = true + def $find(n, n_1 n'* ) = $find( n, n'* ) + Would be transformed as such: + + def $find(nat : nat, nat* ) : bool + def $find{n : nat}(n, []) = false + def $find{n : nat, `n'*` : nat*, n#1 : nat}(n, [n#1] ++ n'*{n' <- `n'*`}) = true + -- if (n = n#1) + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) + + For definite iteration: + + def $len( int* ) : nat + def $len(i^n) = n + + to + + def $len(int* ) : nat + def $len{n : nat, `i*` : int*}(i*{i <- `i*`}) = n + -- if (n = |`i*`|) + +NOTE: Currently does not work with dependent types. As such, it depends on the type family removal pass and undep pass. +This is a todo for the future. +*) + +open Il.Ast +open Il.Walk +open Util +open Source + +module StringMap = Map.Make(String) + +let (let*) = Option.bind + +let create_eq_prem id typ id' = + let idexp = VarE id $$ id.at % typ in + let idexp' = VarE (id' $ id.at) $$ id.at % typ in + let exp = CmpE (`EqOp, `BoolT, idexp, idexp') $$ id.at % (BoolT $ id.at) in + IfPr exp $ id.at + +let create_eq_prem_exp e e' = + let exp = CmpE (`EqOp, `BoolT, e, e') $$ e.at % (BoolT $ e.at) in + IfPr exp $ e.at + +let create_iter_prem scope base_prem = + List.fold_left (fun prem iterexp -> + IterPr (prem, iterexp) $ prem.at + ) base_prem scope + +let t_exp varmap exp = + match exp.it with + | VarE id -> + let fresh_var = ref id.it in + varmap := StringMap.update id.it (fun opt -> + match opt with + | Some lst -> + fresh_var := Utils.generate_var (List.map fst (StringMap.bindings !varmap) @ lst) id.it; + Some (!fresh_var :: lst) + | None -> Some [] + ) !varmap; + { exp with it = VarE (!fresh_var $ id.at) } + | _ -> exp + +let rec c_exp scope exp = + match exp.it with + | IterE (_, (ListN (e'', _), eps)) -> ([e'', eps, scope], true) + | IterE (e, (iter, eps)) -> + let lst_cl = base_collector [] (@) in + let cl = { lst_cl with collect_exp = c_exp ((iter, eps) :: scope) } in + let def_lst = collect_exp cl e in + (def_lst, false) + | _ -> ([], true) + +let t_exp2 exp = + match exp.it with + | IterE (e, (ListN _, eps)) -> { exp with it = IterE (e, (List, eps)) } + | _ -> exp + +let t_typ2 typ = + match typ.it with + | IterT (t, ListN _) -> { typ with it = IterT (t, List) } + | _ -> typ + +let handle_non_linear clause = + let DefD (quants, args, exp, prs) = clause.it in + let varmap = ref StringMap.empty in + let tf = { base_transformer with transform_exp = t_exp varmap; transform_types_of_exp = false } in + let args' = List.map (transform_arg tf) args in + let new_quants, new_prs = List.filter_map (fun q -> match q.it with + | ExpP (id, typ) -> + let* ts = StringMap.find_opt id.it !varmap in + if ts = [] then None else + let q' = List.map (fun id' -> ExpP (id' $ id.at, typ) $ id.at) ts in + let prs'= List.map (create_eq_prem id typ) ts in + Some (q', prs') + | _ -> None + ) quants |> List.split + in + + { clause with it = DefD (quants @ (List.concat new_quants), args', exp, prs @ (List.concat new_prs)) } + +let handle_definite_iter clause = + let DefD (quants, args, exp, prs) = clause.it in + let lst_cl = base_collector [] (@) in + let cl = { lst_cl with collect_exp = c_exp [] } in + let tf = { base_transformer with transform_exp = t_exp2; transform_typ = t_typ2 } in + + let def_lst = List.concat_map (collect_arg cl) args in + let new_prs = List.concat_map (fun (n, eps, scope) -> + let lene e = LenE e $$ e.at % (NumT `NatT $ e.at) in + List.map (fun (_, e) -> + let base_prem = create_eq_prem_exp n (lene e) in + create_iter_prem scope base_prem) eps + ) def_lst + in + + { clause with it = DefD (quants, List.map (transform_arg tf) args, exp, prs @ new_prs) } + +let handle_definite_iter_rel rule = + let RuleD (id, quants, mixop, exp, prs) = rule.it in + let lst_cl = base_collector [] (@) in + let cl = { lst_cl with collect_exp = c_exp [] } in + + let def_lst = collect_exp cl exp @ List.concat_map (collect_prem cl) prs in + let def_lst_uniq = Lib.List.nub (fun (n1, eps1, _) (n2, eps2, _) -> + Il.Eq.eq_exp n1 n2 && List.length eps1 = List.length eps2 && + List.for_all2 (fun (id1, e1) (id2, e2) -> id1.it = id2.it && Il.Eq.eq_exp e1 e2) eps1 eps2 + ) def_lst in + let new_prs = List.concat_map (fun (n, eps, scope) -> + let lene e = LenE e $$ e.at % (NumT `NatT $ e.at) in + List.map (fun (_, e) -> + let base_prem = create_eq_prem_exp n (lene e) in + create_iter_prem scope base_prem) eps + ) def_lst_uniq + in + + { rule with it = RuleD (id, quants, mixop, exp, prs @ new_prs) } + +let rec t_def def = + match def.it with + | DecD (id, params, rt, clauses) -> { def with it = DecD (id, params, rt, + clauses |> List.map handle_definite_iter |> List.map (handle_non_linear)) } + | RelD (id, qs, mixop, typ, rules) -> + { def with it = RelD (id, qs, mixop, typ, List.map handle_definite_iter_rel rules) } + | RecD defs -> { def with it = RecD (List.map t_def defs) } + | _ -> def + +let transform il = List.map t_def il diff --git a/spectec/src/middlend/patSimp.mli b/spectec/src/middlend/patSimp.mli new file mode 100644 index 0000000000..64d020ff9d --- /dev/null +++ b/spectec/src/middlend/patSimp.mli @@ -0,0 +1 @@ +val transform : Il.Ast.script -> Il.Ast.script \ No newline at end of file diff --git a/spectec/src/middlend/sideconditions.ml b/spectec/src/middlend/sideconditions.ml index 81c31b0767..7fa294bace 100644 --- a/spectec/src/middlend/sideconditions.ml +++ b/spectec/src/middlend/sideconditions.ml @@ -6,7 +6,7 @@ open Il.Walk (* Errors *) -let error at msg = Error.error at "side condition" msg +let _error at msg = Error.error at "side condition" msg module Env = Map.Make(String) @@ -21,6 +21,7 @@ let iterPr (pr, (iter, vars)) = let vars' = List.filter (fun (id, _) -> Set.mem id.it frees.varid ) vars in + if iter <= List1 && vars' = [] then pr.it else IterPr (pr, (iter, vars')) let is_null e = CmpE (`EqOp, `BoolT, e, OptE None $$ e.at % e.note) $$ e.at % (BoolT $ e.at) @@ -68,6 +69,7 @@ let rec t_exp env e = collect_iter collector1 iter @ List.map (fun pr -> iterPr (pr, iterexp) $ e.at) (collect_exp collector2 e1), false) | _ -> ([], true) + and t_prem env prem = let res, continue = (match prem.it with | IterPr (prem', ((iter, _) as iterexp)) @@ -127,7 +129,7 @@ let t_params env = List.fold_left (fun env param -> match param.it with | ExpP (v, t) -> Env.add v.it t env - | TypP _ | DefP _ | GramP _ -> error param.at "unexpected paramater or quantifier in rule" + | _ -> env ) env let t_rule' env = function diff --git a/spectec/src/middlend/singlepatternmatch.ml b/spectec/src/middlend/singlepatternmatch.ml new file mode 100644 index 0000000000..3a4a16ca17 --- /dev/null +++ b/spectec/src/middlend/singlepatternmatch.ml @@ -0,0 +1,488 @@ +(* + +In this pass we remove pattern-matchings from two variables. + +Imagine two datatypes A = Aone | Atwo | … | Aonehundred and B = Bone | Btwo | … | Bonehundred + +We would replace the following function: + +f : A -> B -> C +f Aone Bone = Cwhatever +f Atwo Btwo = Csomething + +(which in proof assistants like Isabelle would explode in size as isabelle adds cases like f Aone Btwo = undefined etc for all ten thousand combinations) with three functions + +fAone : B -> C +f Bone = Cwhatever + +fAtwo : B -> C +f Btwo = Csomething + +f : A -> B -> C +f Aone x = fAone x +f Atwo x = fAtwo x + +Here, Isabelle would add 99 cases to fAone, 99 cases to fAtwo and 98 cases to f, instead of the 9998 cases it would otherwise have added to the old f + +Known issue: this can introduce redunt pattern-matching cases! + + *) + +let limit = 100 (* max number of cases we can tolerate *) + +open Il.Ast +open Util.Source +open Xl.Mixop + +let error at msg = Util.Error.error at "Single-patternmatch pass" msg + +module MixopMap = Map.Make(struct type t = unit mixop let compare = compare end) +module StringMap = Map.Make(String) +type datatypes = (typ list * typ) MixopMap.t StringMap.t (* map from type names to maps from constructor names to arg types *) + +(* Helpers: recursivity: *) + + +let rec is_recursive_exp id e = + match e.it with + | VarE id' -> List.mem id'.it id + | BoolE _ + | NumE _ + | TextE _ + | OptE None -> false + | UnE (_, _, e) + | ProjE (e, _) + | CaseE (_, e) + | UncaseE (e, _) + | OptE (Some e) + | TheE e + | DotE (e, _) + | LiftE e + | LenE e + | CvtE (e, _, _) -> is_recursive_exp id e + | BinE (_, _, e1, e2) + | CmpE (_, _, e1, e2) + | CompE (e1, e2) + | MemE (e1, e2) + | CatE (e1, e2) + | IdxE (e1, e2) -> is_recursive_exp id e1 || is_recursive_exp id e2 + | SliceE (e1, e2, e3) + | IfE (e1, e2, e3) -> is_recursive_exp id e1 || is_recursive_exp id e2 || is_recursive_exp id e3 + | TupE es + | ListE es -> List.exists (is_recursive_exp id) es + | StrE es -> List.exists (is_recursive_exp id) (List.map snd es) + | UpdE (e1, p, e2) + | ExtE (e1, p, e2) -> is_recursive_exp id e1 || is_recursive_exp id e2 || is_recursive_path id p + | CallE (id', args) -> List.mem id'.it id || List.exists (is_recursive_arg id) args + | IterE (e, ite) -> is_recursive_exp id e || is_recursive_iterexp id ite + | SubE (e, t1, t2) -> is_recursive_exp id e || is_recursive_typ id t1 || is_recursive_typ id t2 + +and is_recursive_typ id typ = + match typ.it with + | VarT (_, args) -> List.exists (is_recursive_arg id) args + | BoolT | NumT _ | TextT -> false + | TupT ts -> List.exists (is_recursive_typ id) (List.map snd ts) + | IterT (t, i) -> is_recursive_typ id t || is_recursive_iter id i + +and is_recursive_iter id = function + | ListN (e, _) -> is_recursive_exp id e + | _ -> false + +and is_recursive_arg id arg = + match arg.it with + | ExpA e -> is_recursive_exp id e + | TypA t -> is_recursive_typ id t + | DefA _ -> false + | GramA s -> is_recursive_sym id s + +and is_recursive_sym id sym = + match sym.it with + | VarG (_, args) -> List.exists (is_recursive_arg id) args + | NumG _ + | TextG _ + | EpsG -> false + | SeqG syms + | AltG syms -> List.exists (is_recursive_sym id) syms + | RangeG (sym1, sym2) -> is_recursive_sym id sym1 || is_recursive_sym id sym2 + | IterG (s, ite) -> is_recursive_sym id s || is_recursive_iterexp id ite + | AttrG (e, s) -> is_recursive_exp id e || is_recursive_sym id s + +and is_recursive_iterexp id = function + | (it, es) -> is_recursive_iter id it || List.exists (is_recursive_exp id) (List.map snd es) + +and is_recursive_path id path = + match path.it with + | RootP -> false + | IdxP (p, e) -> is_recursive_path id p || is_recursive_exp id e + | SliceP (p, e1, e2) -> is_recursive_path id p || is_recursive_exp id e1 || is_recursive_exp id e2 + | DotP (p, _) -> is_recursive_path id p + + +let is_recursive_clause id clause = + match clause.it with + | DefD (_, _, e, _) -> is_recursive_exp id e + +let rec is_recursive id def = + match def.it with + | DecD (_, _, _, clauses) -> + List.exists (is_recursive_clause id) clauses + | RecD defs -> List.exists (is_recursive id) defs + | _ -> error def.at "generated defs should only be decs and recs" + +(* helpers: substitution *) + +let rec subst_exp x v e = + let f x = { e with it = x } in + let g = subst_exp x v in + match e.it with + | VarE y when y.it = x -> v + | VarE _ + | BoolE _ + | NumE _ + | TextE _ + | OptE None -> e + | UnE (a, b, e) -> f (UnE (a, b, g e)) + | BinE (a, b, e1, e2) -> f (BinE (a, b, g e1, g e2)) + | CmpE (a, b, e1, e2) -> f (CmpE (a, b, g e1, g e2)) + | TupE es -> f (TupE (List.map g es)) + | ProjE (e, i) -> f (ProjE (g e, i)) + | CaseE (a, e) -> f (CaseE (a, g e)) + | UncaseE (e, a) -> f (UncaseE (g e, a)) + | OptE (Some e) -> f (OptE (Some (g e))) + | TheE e -> f (TheE (g e)) + | StrE es -> f (StrE (List.map (fun (a, e) -> (a, g e)) es)) + | DotE (e, a) -> f (DotE (g e, a)) + | CompE (e1, e2) -> f (CompE (g e1, g e2)) + | ListE es -> f (ListE (List.map g es)) + | LiftE e -> f (LiftE (g e)) + | MemE (e1, e2) -> f (MemE (g e1, g e2)) + | LenE e -> f (LenE (g e)) + | CatE (e1, e2) -> f (CatE (g e1, g e2)) + | IdxE (e1, e2) -> f (IdxE (g e1, g e2)) + | SliceE (e1, e2, e3) -> f (SliceE (g e1, g e2, g e3)) + | UpdE (e1, p, e2) -> f (UpdE (g e1, subst_path x v p, g e2)) + | ExtE (e1, p, e2) -> f (ExtE (g e1, subst_path x v p, g e2)) + | IfE (e1, e2, e3) -> f (IfE (g e1, g e2, g e3)) + | CallE (id, args) -> f (CallE (id, List.map (subst_arg x v) args)) + | IterE (e, ite) -> f (IterE (g e, subst_iterexp x v ite)) + | CvtE (e, a, b) -> f (CvtE (g e, a, b)) + | SubE (e, t1, t2) -> f (SubE (g e, subst_typ x v t1, subst_typ x v t2)) + +and subst_typ x v t = + match t.it with + | VarT (id, args) -> { t with it = VarT (id, List.map (subst_arg x v) args) } + | BoolT + | NumT _ + | TextT -> t + | TupT l -> { t with it = TupT (List.map (fun (a, t) -> (a, subst_typ x v t)) l) } + | IterT (t, i) -> { t with it = IterT (subst_typ x v t, subst_iter x v i) } + +and subst_iter x v = function + | Opt -> Opt + | List -> List + | List1 -> List1 + | ListN (e, i) -> ListN (subst_exp x v e, i) + +and subst_iterexp x v (i, l) = (subst_iter x v i, List.map (fun (i, e) -> (i, subst_exp x v e)) l) + +and subst_arg x v a = + match a.it with + | ExpA e -> { a with it = ExpA (subst_exp x v e) } + | TypA t -> { a with it = TypA (subst_typ x v t) } + | DefA _ -> a + | GramA s -> { a with it = GramA (subst_sym x v s) } + +and subst_sym x v s = + match s.it with + | VarG (i, args) -> { s with it = VarG (i, List.map (subst_arg x v) args) } + | NumG _ + | TextG _ + | EpsG -> s + | SeqG syms -> { s with it = SeqG (List.map (subst_sym x v) syms) } + | AltG syms -> { s with it = AltG (List.map (subst_sym x v) syms) } + | RangeG (s1, s2) -> { s with it = RangeG (subst_sym x v s1, subst_sym x v s2) } + | IterG (sym, ite) -> { s with it = IterG (subst_sym x v sym, subst_iterexp x v ite) } + | AttrG (e, sym) -> { s with it = AttrG (subst_exp x v e, subst_sym x v sym) } + +and subst_path x v p = + match p.it with + | RootP -> p + | IdxP (path, e) -> { p with it = IdxP (subst_path x v path, subst_exp x v e) } + | SliceP (path, e1, e2) -> { p with it = SliceP (subst_path x v path, subst_exp x v e1, subst_exp x v e2) } + | DotP (path, a) -> { p with it = DotP (subst_path x v path, a) } + + + +(* other helpers *) + +let is_typ_param x = + match x.it with + | TypP _ -> true + | _ -> false +let is_typ_arg x = + match x.it with + | TypA _ -> true + | _ -> false +let has_prems c = + let only_otherwise prems = + match prems with + | [{it = ElsePr; _}] -> true + | _ -> false + in + match c.it with + | DefD (_, _, _, prems) -> prems <> [] && not (only_otherwise prems) + +let transform_case_tup e = + match e.it with + | TupE exps -> exps + | _ -> [e] + +let transform_case_typ t = + match t.it with + | TupT typs -> List.map snd typs + | _ -> [t] + +let package_case_tup l at typ = + match l with + | [e] -> e + | _ -> TupE l $$ (at, typ) + +let rec get_arg_types = function + | (op, (t, _, _), _) :: q -> + MixopMap.add ((* to_string *) op) (transform_case_typ t, t) (get_arg_types q) + | [] -> MixopMap.empty + +let rec get_constr_strings exp = + match exp.it with + | CaseE (op, arg) -> + let args = transform_case_tup arg in + let suffs = List.map get_constr_strings args |> List.flatten in + [(* to_string *) op] :: List.map (fun suff -> (* to_string *) op :: suff) suffs + | _ -> [] + +let inspect_clause_constr_strings clause = + match clause.it with + | DefD (_, args, _, _) -> + List.map (fun arg -> + match arg.it with + | ExpA exp -> get_constr_strings exp + | _ -> []) args + +let rec count_cases (datatypes : datatypes) typ constructor_strings = + (* may overcount if datatypes share constructor names but that is fine *) + match typ.it with + | VarT (typid, _) -> + if StringMap.mem typid.it datatypes then + let cases = StringMap.find typid.it datatypes in + if constructor_strings = [] then 1 + else + MixopMap.fold (fun casename (argtypes, _) total -> + let constructor_strings = List.filter_map (function + | t :: t' :: q when t = casename -> Some (t' :: q) + | _ -> None) constructor_strings in + if constructor_strings = [] then total + 1 else + total + (List.map (fun typ -> count_cases datatypes typ constructor_strings) + argtypes |> List.fold_left ( * ) 1)) cases 0 + else 1 + | _ -> 1 + +let inspect_clause_depth dummy_arglist clauses = + List.fold_left (fun acc clause -> + match clause.it with + | DefD (_, args, _, _) -> + List.map2 (fun (n, seen_catchall) arg -> + if seen_catchall then (n, true) else + match arg.it with + | ExpA { it = CaseE _ ; _ } -> (n + 1, false) + | _ -> (n, true)) acc args) (List.map (fun _ -> (0, false)) dummy_arglist) clauses |> List.map fst + +let rec find_deepest = function + | [] -> 0, 0 + | n :: q -> let i, v = find_deepest q in + if n >= v then 0, n + else i + 1, v + +let rec get_nth i = function + | [] -> failwith "list too short" + | t :: q -> if i = 0 then t else get_nth (i - 1) q + +let rec replace_nth i l = function + | [] -> failwith "list too short" + | t :: q -> if i = 0 then l @ q else t :: replace_nth (i - 1) l q + +(* let insert_clause op clause newclauses = + let l = if MixopMap.mem op newclauses then MixopMap.find op newclauses else [] in + MixopMap.add op (clause :: l) newclauses *) + +(* let rec separate_clauses newclauses casei clauses = + match clauses with + | clause :: q -> + begin match clause.it with + | DefD (quants, args, exp, prems) -> + let argi = get_nth casei args in + match argi.it with + | ExpA expi -> + begin match expi.it with + | CaseE (op, e) -> + let es = transform_case_tup e in + let es = List.map (fun e -> {argi with it = ExpA e}) es in + let newargs = replace_nth casei es args in + let newclause = { clause with it = DefD (quants, newargs, exp, prems) } in + separate_clauses (insert_clause op newclause newclauses) casei q + | _ -> newclauses, clauses + end + | _ -> failwith "this argument should be an expression" + end + | _ -> newclauses, [] *) + +let generate_dummy_exps typs at = + List.mapi (fun i t -> + VarE ("constructor_parameter_" ^ string_of_int i $ at) $$ (at, t)) typs + +let rec generate_args params : arg list = + List.map (fun param -> + let at = param.at in + match param.it with + | ExpP (id, t) -> (ExpA (VarE id $$ (at, t)) $ at) + | TypP id -> (TypA (VarT (id, []) $ at) $ at) + | DefP (id,_,_) -> (DefA id $ at) + | GramP (id, params, _) -> (GramA (VarG (id, generate_args params) $ at) $ at) + ) params + +let generate_dummy_args l at = + List.map (fun e -> ExpA e $ at) (generate_dummy_exps l at) +let generate_dummy_params l at = + let es = generate_dummy_exps l at in + List.map (fun e -> + match e.it with + | VarE id -> ExpP (id, e.note) $ e.at + | _ -> error e.at "dummy exps are always vars") es + + +let generate_split_clauses clauses casei op paramtyps packagedparamtyps = + List.filter_map (fun clause -> + match clause.it with + | DefD (quants, args, exp, prems) -> + let argi = get_nth casei args in + match argi.it with + | ExpA e -> + begin match e.it with + | VarE x -> + Some (DefD (generate_dummy_params paramtyps clause.at @ quants, + replace_nth casei (generate_dummy_args paramtyps clause.at) args, + subst_exp x.it ((CaseE (op, package_case_tup (generate_dummy_exps paramtyps clause.at) e.at packagedparamtyps) $$ (e.at, e.note))) exp, + prems) $ clause.at) + | CaseE (op', e) when to_string op = to_string op' -> + let es = transform_case_tup e in + let es = List.map (fun e -> {argi with it = ExpA e}) es in + let newargs = replace_nth casei es args in + Some { clause with it = DefD (quants, newargs, exp, prems) } + | CaseE _ -> + None + | _ -> error e.at "this pattern-matching case should be a constructor or a variable" + end + | _ -> error argi.at "this pattern-matching case should be on expression arguments" + ) clauses + +let get_rec_names defs = + List.filter_map (fun def -> + match def.it with + | DecD (id, _, _, _) -> Some id.it + | _ -> None) defs + +let is_catchall cl = + match cl.it with + | DefD (_, args, _, _) -> + List.for_all (fun arg -> + match arg.it with + | ExpA e -> + begin match e.it with + | VarE _ -> true + | _ -> false end + | _ -> true) args + +let rec stop_at_first_catchall = function + | [] -> [] + | cl :: _ when is_catchall cl -> [cl] + | t :: q -> t :: stop_at_first_catchall q + +let rec transform_def (datatypes : datatypes) rec_names def = + match def.it with + | TypD (id, _, [{it = InstD (_, _, {it = VariantT typcases; _}); _}]) -> + StringMap.add id.it (get_arg_types typcases) datatypes, [def] + | DecD (_, params, _, [{it = DefD (quants, args, _, _); _}]) + when List.for_all is_typ_param params && List.for_all is_typ_arg args && List.for_all is_typ_param quants -> + datatypes, [def] + | DecD (_, _, _, []) -> + datatypes, [def] + | DecD (_, _, _, clauses) when List.exists has_prems clauses -> + datatypes, [def] + | DecD (id, params, typ, clauses) -> + let constructor_strings = + List.fold_left (fun constructor_strings clause -> + List.map2 (@) (inspect_clause_constr_strings clause) constructor_strings) (List.map (fun _ -> []) params) clauses in + let estimate_of_size = List.map2 (fun paramtyp constructor_strings -> + match paramtyp.it with + | ExpP (_, paramtyp) -> + count_cases datatypes paramtyp constructor_strings + | _ -> 1) params constructor_strings + |> List.fold_left ( * ) 1 in + (* Printf.printf "function %s has size %d\n" id.it estimate_of_size; *) + if estimate_of_size <= limit then datatypes, [def] else + let pattern_match_depths = inspect_clause_depth params clauses in + let casei, depth = find_deepest pattern_match_depths in + if depth = 0 then + datatypes, [{ def with it = DecD (id, params, typ, [List.hd clauses])}] + else + (* let case_clauses, catchall_clauses = separate_clauses MixopMap.empty casei clauses in *) + let splittypid = get_nth casei params in + let splittypid, splittyp = match splittypid.it with + | ExpP (_, ({it = VarT (id, _) ; _} as t)) -> id.it, t + | _ -> error splittypid.at "chosen case should be a datatype" in + let splittypparams = StringMap.find splittypid datatypes in + let new_defs, toplevelclauses = + MixopMap.fold (fun op (paramtyps, packaged_paramtyps) (new_defs, toplevelclauses) -> + let split_clauses = generate_split_clauses clauses casei op paramtyps packaged_paramtyps in + let split_clauses = stop_at_first_catchall split_clauses in + match split_clauses with + | [] -> new_defs, toplevelclauses + | _ -> (DecD ({ id with it = id.it ^ "_" ^ to_string op }, + replace_nth casei + (List.mapi (fun i t -> ExpP (to_string op ^ "_argument_" ^ string_of_int i $ id.at, t) $ id.at) paramtyps) params, + typ, + split_clauses) $ def.at) :: new_defs, + (DefD (replace_nth casei (generate_dummy_params paramtyps id.at) params, + replace_nth casei + [ExpA + (CaseE + (op, + package_case_tup ( + generate_dummy_exps paramtyps id.at) id.at packaged_paramtyps) $$ (id.at, splittyp)) $ id.at] + (generate_args params), + CallE ({id with it = id.it ^ "_" ^ to_string op}, + replace_nth casei + (generate_dummy_args paramtyps id.at) + (generate_args params)) $$ (id.at, typ), + []) $ id.at) :: toplevelclauses + ) splittypparams ([], []) in + let new_defs = List.map (fun def -> snd (transform_def datatypes rec_names def)) new_defs |> List.flatten in + let topleveldef = + DecD (id, params, typ, toplevelclauses) $ def.at in + let yes_rec, not_rec = List.partition (is_recursive (if rec_names = [] then [id.it] else rec_names)) new_defs in + begin match yes_rec with + | [] -> datatypes, new_defs @ [topleveldef] + | _ -> datatypes, not_rec @ [RecD (yes_rec @ [topleveldef]) $ def.at] + end + | RecD defs -> + let rec_names = rec_names @ get_rec_names defs in + let datatypes, defs = List.fold_left (fun (datatypes, defs) def -> + let datatypes, def = transform_def datatypes rec_names def in + datatypes, def :: defs) (datatypes, []) defs in + datatypes, [{ def with it = RecD (List.flatten (List.rev defs)) }] + | _ -> datatypes, [def] + +let transform script = + let _, script = List.fold_left (fun (datatypes, defs) def -> + let datatypes, def = transform_def datatypes [] def in + datatypes, def :: defs) (StringMap.empty, []) script in + List.flatten (List.rev script) diff --git a/spectec/src/middlend/sub.ml b/spectec/src/middlend/sub.ml index 80a7c3a489..81e4538c17 100644 --- a/spectec/src/middlend/sub.ml +++ b/spectec/src/middlend/sub.ml @@ -95,7 +95,7 @@ let rec t_exp env exp = let new_iterid = Il.Fresh.fresh_varid "iter_val" in let new_exp = VarE (new_iterid $ e.at) $$ e.at % t1 in let new_iterexp = (iter1, [(new_iterid $ e.at, e)]) in - IterE (SubE (new_exp, t1, t2) $$ e.at % t2, new_iterexp) $$ e.at % sup_ty + IterE (t_exp env (SubE (new_exp, t1, t2) $$ e.at % t2), new_iterexp) $$ e.at % sup_ty | _, _ -> (* Printf.eprintf "[sub @ %s REMAINS] %s <: %s\n%!" (string_of_region exp'.at) (Il.Print.string_of_typ sub_ty) (Il.Print.string_of_typ sup_ty); *) error sub_ty.at ("Non-variable or number type expression not supported `" ^ Il.Print.string_of_typ sub_ty ^ "`") @@ -148,7 +148,7 @@ let rec rename_params s = function let lookup_arg_typ typcases m = List.find_map (fun (m', (arg_typ, _, _), _) -> if Il.Eq.eq_mixop m m' then Some arg_typ else None) typcases -let insert_injections env (def : def) : def list = +let insert_injections transformer env (def : def) : def list = add_type_info env def; let pairs = ready_pairs env in [ def ] @ @@ -177,7 +177,7 @@ let insert_injections env (def : def) : def list = let xe is_lhs = TupE (xes is_lhs) $$ no_region % arg_typ in DefD (quants, [ExpA (CaseE (m, xe true) $$ no_region % real_ty) $ no_region], - t_exp env (CaseE (m, xe false) $$ no_region % sup_ty), []) $ no_region + transform_exp transformer (CaseE (m, xe false) $$ no_region % sup_ty), []) $ no_region | _ -> let x = "x" $ no_region in let xe = VarE x $$ no_region % arg_typ in @@ -194,6 +194,6 @@ let transform (defs : script) = let transformer = { base_transformer with transform_exp = t_exp env } in let defs' = List.map (transform_def transformer) defs in env.pairs_mutable <- false; - let defs'' = List.concat_map (insert_injections env) defs' in + let defs'' = List.concat_map (insert_injections transformer env) defs' in S.iter (fun (sub, sup) -> error sup.at ("left-over subtype coercion `" ^ sub.it ^ "` <: `" ^ sup.it ^ "`")) env.pairs; defs'' diff --git a/spectec/src/middlend/subexpansion.ml b/spectec/src/middlend/subexpansion.ml index 94b9d5ccdb..a91e558884 100644 --- a/spectec/src/middlend/subexpansion.ml +++ b/spectec/src/middlend/subexpansion.ml @@ -5,6 +5,7 @@ open Source open Il.Ast open Il open Il.Walk +open Il.Subst (* Errors *) @@ -118,9 +119,12 @@ let generate_subst_list lhs quants = (* Compute cartesian product for all cases and generate a subst *) let cases' = product_of_lists cases in - List.map (List.fold_left (fun (quants, subst) (id, (quants', exp)) -> + let subst_list = List.map (List.fold_left (fun (quants, subst) (id, (quants', exp)) -> (quants' @ quants, Il.Subst.add_varid subst id exp)) ([], Il.Subst.empty) - ) cases' + ) cases' in +Lib.List.nub (fun (quants', subst) (quants'', subst') -> + Eq.eq_list Eq.eq_param quants' quants'' && Map.equal (fun exp exp' -> Eq.eq_exp exp exp') subst.varid subst'.varid + ) subst_list let t_clause clause = match clause.it with diff --git a/spectec/src/middlend/typefamilyremoval.ml b/spectec/src/middlend/typefamilyremoval.ml index 5d9000e2b6..dd6f404245 100644 --- a/spectec/src/middlend/typefamilyremoval.ml +++ b/spectec/src/middlend/typefamilyremoval.ml @@ -11,7 +11,10 @@ type family_data = (id * quant list * Subst.t * int * typ * typ) let error at msg = Error.error at "Type families removal" msg let projection_hint_id = "tf_projection_func" -let projection_hint = { hintid = projection_hint_id $ no_region; hintexp = El.Ast.SeqE [] $ no_region} +let projection_hint = { hintid = projection_hint_id $ no_region; hintexp = El.Ast.SeqE [] $ no_region } + +let type_family_hint_id = "type_family" +let type_family_hint = { hintid = type_family_hint_id $ no_region; hintexp = El.Ast.SeqE [] $ no_region } let quant_to_string quant = match quant.it with @@ -27,7 +30,9 @@ let iter_var_name = "iter_" let name_prefix id = id.it ^ "_" let empty_info typ_id: region * Xl.Atom.info = (no_region, {def = typ_id; case = ""}) -let sub_type_name_quants quants = (String.concat "_" (List.map quant_to_string quants)) +let sub_type_name_quants quants i = + let s = (String.concat "_" (List.map quant_to_string quants)) in + if s = "" then "_" ^ Int.to_string i else s let constructor_name' id case_num = make_prefix ^ name_prefix id ^ Int.to_string case_num let constructor_name_mixop id num_quants case_num: mixop = Xl.Mixop.(Seq (Atom (Xl.Atom.Atom (constructor_name' id case_num) $$ empty_info id.it) @@ -125,15 +130,15 @@ let has_one_inst env family_typ = ) | _ -> false -let extend_quant_set set quants = - List.fold_left (fun acc q -> +let extend_quant_set env set quants = + List.fold_left (fun (env, quant_set) q -> match q.it with - | ExpP (id, typ) -> StringMap.add id.it typ acc - | DefP (id, _, typ) -> StringMap.add id.it typ acc - | _ -> acc - ) set quants + | ExpP (id, typ) -> (env, StringMap.add id.it typ quant_set) + | DefP (id, params, typ) -> (Env.bind_def env id (params, typ, []), quant_set) + | _ -> (env, quant_set) + ) (env, set) quants -let make_quant_set quants = extend_quant_set StringMap.empty quants +let make_quant_set env quants = extend_quant_set env StringMap.empty quants let rec check_type_equality env t t' = let r_t = reduce_type_aliasing env t in @@ -162,10 +167,7 @@ let rec get_real_typ_from_exp quant_map env e = let s_typ = Subst.subst_typ subst typ in s_typ | None -> - (match StringMap.find_opt id.it quant_map with - | Some typ -> typ - | None -> e.note - ) + e.note ) | CaseE (m, _) -> let r_typ = Eval.reduce_typ env e.note in @@ -454,7 +456,9 @@ let rec transform_prem quant_map env prem = RulePr (id, List.map (transform_arg quant_map env) args, m, transform_exp quant_map env e) | IfPr e -> quant_map, IfPr (transform_exp quant_map env e) | LetPr (quants, e1, e2) -> - let new_quant_map = extend_quant_set quant_map quants in + (* NOTE: for let since we only have expressions we cannot modify the env ever. *) + let env', new_quant_map = extend_quant_set env quant_map quants in + assert (env = env'); new_quant_map, LetPr (List.map (transform_param env) quants, transform_exp new_quant_map env e1, transform_exp quant_map env e2) | ElsePr -> quant_map, ElsePr @@ -477,12 +481,12 @@ let rec transform_prems quant_map env = function let transform_rule env rule = match rule.it with | RuleD (id, quants, m, exp, prems) -> - let quant_map = make_quant_set quants in - let new_quant_map, new_prems = transform_prems quant_map env prems in + let env', quant_map = make_quant_set env quants in + let new_quant_map, new_prems = transform_prems quant_map env' prems in RuleD (id, - List.map (transform_param env) quants, + List.map (transform_param env') quants, m, - transform_exp new_quant_map env exp, + transform_exp new_quant_map env' exp, new_prems ) $ rule.at @@ -497,14 +501,14 @@ let transform_clause _id params env rt clause = | DefD (quants, args, exp, prems) -> let subst = create_arg_param_subst args params in let reduced_quants = List.map (reduce_quant env) quants in - let quant_map = make_quant_set reduced_quants in - let new_quant_map, new_prems = transform_prems quant_map env prems in - let t_exp = transform_exp new_quant_map env exp in - let real_typ = get_real_typ_from_exp new_quant_map env t_exp in + let env', quant_map = make_quant_set env reduced_quants in + let new_quant_map, new_prems = transform_prems quant_map env' prems in + let t_exp = transform_exp new_quant_map env' exp in + let real_typ = get_real_typ_from_exp new_quant_map env' t_exp in let s_rt = Subst.subst_typ subst rt in - let new_exp = if check_type_equality env real_typ s_rt then t_exp else apply_conversion env t_exp real_typ s_rt in - DefD ((List.map (transform_param env) reduced_quants), - List.map (transform_arg quant_map env) args, + let new_exp = if check_type_equality env' real_typ s_rt then t_exp else apply_conversion env' t_exp real_typ s_rt in + DefD ((List.map (transform_param env') reduced_quants), + List.map (transform_arg quant_map env') args, new_exp, new_prems ) $ clause.at @@ -512,11 +516,11 @@ let transform_clause _id params env rt clause = let transform_prod env prod = (match prod.it with | ProdD (quants, sym, exp, prems) -> - let quant_map = make_quant_set quants in - let new_quant_map, new_prems = transform_prems quant_map env prems in - ProdD (List.map (transform_param env) quants, - transform_sym quant_map env sym, - transform_exp new_quant_map env exp, + let env', quant_map = make_quant_set env quants in + let new_quant_map, new_prems = transform_prems quant_map env' prems in + ProdD (List.map (transform_param env') quants, + transform_sym quant_map env' sym, + transform_exp new_quant_map env' exp, new_prems ) ) $ prod.at @@ -525,13 +529,13 @@ let transform_deftyp env deftyp = (match deftyp.it with | AliasT typ -> AliasT (transform_typ StringMap.empty env typ) | StructT typfields -> StructT (List.map (fun (a, (t, qs, prems), hints) -> - let quant_map = make_quant_set qs in - let _, new_prems = transform_prems quant_map env prems in - (a, (transform_typ quant_map env t, List.map (transform_param env) qs, new_prems), hints)) typfields) + let env', quant_map = make_quant_set env qs in + let _, new_prems = transform_prems quant_map env' prems in + (a, (transform_typ quant_map env' t, List.map (transform_param env') qs, new_prems), hints)) typfields) | VariantT typcases -> VariantT (List.map (fun (m, (t, qs, prems), hints) -> - let quant_map = make_quant_set qs in - let _, new_prems = transform_prems quant_map env prems in - (m, (transform_typ quant_map env t, List.map (transform_param env) qs, new_prems), hints)) typcases) + let env', quant_map = make_quant_set env qs in + let _, new_prems = transform_prems quant_map env' prems in + (m, (transform_typ quant_map env' t, List.map (transform_param env') qs, new_prems), hints)) typcases) ) $ deftyp.at let transform_inst env inst = @@ -540,14 +544,14 @@ let transform_inst env inst = [InstD (List.map (transform_param env) quants, List.map (transform_arg StringMap.empty env) args, transform_deftyp env deftyp) $ inst.at] (* Creates new TypD's for each StructT and VariantT *) -let create_types id inst = +let create_types idx id inst = match inst.it with | InstD (quants, _, deftyp) -> (match deftyp.it with | AliasT _ -> [] | StructT _ | VariantT _ -> let inst = InstD (quants, List.map make_arg quants, deftyp) $ inst.at in - [TypD (id.it ^ sub_type_name_quants quants $ id.at, quants, [inst])] + [TypD (id.it ^ sub_type_name_quants quants idx $ id.at, quants, [inst])] ) let rec transform_def env def = @@ -594,10 +598,10 @@ let gen_family_projections id has_one_inst case_num inst = let rec create_types_from_instances def = (match def.it with | TypD (id, params, [inst]) when check_normal_type_creation inst -> [TypD (id, params, [inst])] - | TypD (id, params, insts) -> let types = List.concat_map (create_types id) insts in - let transformed_instances = List.map (fun inst -> match inst.it with + | TypD (id, params, insts) -> let types = List.mapi (fun i inst -> create_types i id inst) insts |> List.concat in + let transformed_instances = List.mapi (fun i inst -> match inst.it with | InstD (quants, args, {it = StructT _; at; _}) | InstD (quants, args, {it = VariantT _; at; _}) -> - InstD (quants, args, AliasT (VarT (id.it ^ sub_type_name_quants quants $ id.at, List.map make_arg quants) $ id.at) $ at) $ inst.at + InstD (quants, args, AliasT (VarT (id.it ^ sub_type_name_quants quants i $ id.at, List.map make_arg quants) $ id.at) $ at) $ inst.at | _ -> inst ) insts in types @ [TypD(id, params, transformed_instances)] @@ -634,7 +638,8 @@ let rec transform_type_family def = in let proj_ids, projections = List.split (List.mapi (gen_family_projections id one_inst) insts) in - let hintdefs = List.map (fun id -> HintD (DecH (id, [projection_hint]) $ def.at)) proj_ids in + let hintdefs = HintD (TypH (id, [type_family_hint]) $ def.at) :: + List.map (fun id' -> HintD (DecH (id', [projection_hint]) $ def.at)) proj_ids in TypD (id, params, [inst]) :: projections @ hintdefs | RecD defs -> [RecD (List.concat_map transform_type_family defs)] | d -> [d] diff --git a/spectec/src/middlend/typefamilyremoval.mli b/spectec/src/middlend/typefamilyremoval.mli index 9deda302c9..4c5b8355ba 100644 --- a/spectec/src/middlend/typefamilyremoval.mli +++ b/spectec/src/middlend/typefamilyremoval.mli @@ -48,4 +48,5 @@ Names were specifically chosen here for simplicity. *) val projection_hint_id : string +val type_family_hint_id : string val transform : Il.Ast.script -> Il.Ast.script diff --git a/spectec/src/middlend/uncaseremoval.ml b/spectec/src/middlend/uncaseremoval.ml index 3e3803a7a4..1fd3d45d63 100644 --- a/spectec/src/middlend/uncaseremoval.ml +++ b/spectec/src/middlend/uncaseremoval.ml @@ -48,10 +48,16 @@ let make_arg p = | GramP (_, _, _) -> assert false (* Avoid this *) ) $ p.at +let uncase_proj_hint_id = "uncase-proj-func" + +let generate_proj_func_hint at: hint = { hintid = uncase_proj_hint_id $ at; hintexp = El.Ast.SeqE [] $ at} + + let create_projection_functions id params mixops inst = let get_deftyp inst' = (match inst'.it with | InstD (_quants, _args, deftyp) -> deftyp.it ) in + let proj_name idx = (proj_prefix ^ id.it ^ "_" ^ Int.to_string idx) $ id.at in let at = inst.at in let user_typ = VarT (id, List.map make_arg params) $ at in let param_ids = List.map (fun p -> (Utils.get_param_id p).it) params in @@ -69,7 +75,7 @@ let create_projection_functions id params mixops inst = let new_arg = ExpA new_case_exp $ at in if has_one_case then let clause = DefD (params @ new_quants, List.map make_arg params @ [new_arg], new_tup, []) $ at in - DecD ((proj_prefix ^ id.it ^ "_" ^ Int.to_string idx) $ id.at, new_params, no_name_tupt, [clause]) + DecD (proj_name idx, new_params, no_name_tupt, [clause]) else (* extra handling in case that it has more than one case *) let extra_arg = ExpA (VarE (fresh_name $ at) $$ at % user_typ) $ at in @@ -79,10 +85,10 @@ let create_projection_functions id params mixops inst = let opt_tup = OptE (Some new_tup) $$ at % opt_type in let clause' = DefD (params @ new_quants, List.map make_arg params @ [new_arg], opt_tup, []) $ at in let extra_clause = DefD (params @ new_quants @ [new_quant], List.map make_arg params @ [extra_arg], none_exp, []) $ at in - DecD ((proj_prefix ^ id.it ^ "_" ^ Int.to_string idx) $ id.at, new_params, opt_type, [clause'; extra_clause]) + DecD (proj_name idx, new_params, opt_type, [clause'; extra_clause]) in - List.map (fun m -> + List.concat_map (fun m -> (match (get_deftyp inst) with (* Should not happen due to reduction while collecting uncase expressions *) | AliasT _typ -> error inst.at "Found type alias while constructing projection functions, should not happen" @@ -94,7 +100,10 @@ let create_projection_functions id params mixops inst = Some (i, m, t) ) (List.mapi (fun i t -> (i, t)) typcases) in begin match mixop_opt with - | Some (i, m, t) -> make_func m (get_case_typs t) (List.length typcases = 1) i + | Some (idx, m, t) -> + make_func m (get_case_typs t) (List.length typcases = 1) idx :: + (* Add hint to distinguish this projection function from other functions *) + [ HintD (DecH (proj_name idx, [generate_proj_func_hint id.at]) $ id.at) ] | None -> error inst.at ("Could not find mixop " ^ Il.Print.string_of_mixop m ^ " while constructing projection functions") diff --git a/spectec/src/middlend/uncaseremoval.mli b/spectec/src/middlend/uncaseremoval.mli index 210d82435f..d7275efbc7 100644 --- a/spectec/src/middlend/uncaseremoval.mli +++ b/spectec/src/middlend/uncaseremoval.mli @@ -46,3 +46,4 @@ Names were specifically chosen here for simplicity. *) val transform : Il.Ast.script -> Il.Ast.script +val uncase_proj_hint_id : string diff --git a/spectec/src/middlend/undep.ml b/spectec/src/middlend/undep.ml index 535e352d5d..5529648b8a 100644 --- a/spectec/src/middlend/undep.ml +++ b/spectec/src/middlend/undep.ml @@ -9,26 +9,56 @@ module StringSet = Set.Make(String) type env = { mutable wf_set : StringSet.t; - mutable proj_set : StringSet.t; mutable il_env : Il.Env.t; + + (* Hint sets *) + mutable proj_set : StringSet.t; + mutable tf_set : StringSet.t; + mutable wfopt_set : StringSet.t; + mutable il_hintenv : Hints.t } let empty () = { wf_set = StringSet.empty; + il_env = Il.Env.empty; proj_set = StringSet.empty; - il_env = Il.Env.empty + tf_set = StringSet.empty; + wfopt_set = StringSet.empty; + il_hintenv = Hints.empty } let wf_pred_prefix = "wf_" let rule_prefix = "case_" -let wf_hint_id = "wf-relation" +let wf_lemma_suffix = "_is_wf" -(* flag that deactivates adding wellformedness predicates to relations *) -let deactivate_wfness = false +let wf_hint_id = "wf-relation" +let wf_func_id = "wf-lemma-func" +let wf_rel_id = "wf-lemma-rel" +let wf_opt_id = "wfopt" + +type wfstate = + | WfAll (* Places wf premises whenever it encounters a term/variable that needs well-formedness check*) + | WfMinimal (* Places only wf premises in terms in relations and functions that do not appear in the conclusion *) + | WfNone (* Does not place any wf premises in relations/functions *) + +type wfdef = + | Rel of id + | Func + +(* State that indicates what the placement algorithm should do *) +let wf_state : wfstate ref = ref WfMinimal let error at msg = error at "Undep error" msg +let make_arg p = + (match p.it with + | ExpP (id, typ) -> ExpA (VarE id $$ id.at % typ) + | TypP id -> TypA (VarT (id, []) $ id.at) + | DefP (id, _, _) -> DefA id + | GramP (id, _, _) -> GramA (VarG (id, []) $ id.at) + ) $ p.at + let rec split3concat = function [] -> ([], [], []) | (x,y, z)::l -> @@ -67,6 +97,13 @@ let check_iter free_set iter = | ListN (_, Some id) -> Free.Set.mem id.it free_set | _ -> false +let has_wf_opt env rid = StringSet.mem rid.it env.wfopt_set + +let can_optimize wfdef env = + match wfdef with + | Func -> true (* Functions can always be optimized because mode is always known *) + | Rel id -> has_wf_opt env id (* Relations need wf opt hint *) + let filter_iter_quants exp iter_quants = let free_vars = (Free.free_exp exp).varid in (List.fold_left (fun (free_set, acc) (iter, id_exp_pairs) -> @@ -92,25 +129,27 @@ let filter_iter_quants exp iter_quants = ) (free_vars, []) iter_quants) |> snd |> List.rev -let rec create_collector iterexps = +let rec create_collector wfdef env iterexps = let base_collector_iters: ((exp * typ) * iterexp list) list collector = base_collector [] (@) in - { base_collector_iters with collect_exp = collect_userdef_exp iterexps; collect_prem = collect_userdef_prem iterexps } + { base_collector_iters with collect_exp = collect_userdef_exp wfdef env iterexps; collect_prem = collect_userdef_prem wfdef env iterexps } -and collect_userdef_exp iterexps e = +and collect_userdef_exp wfdef env iterexps e = match e.it with + | CallE (id, _) when not (StringSet.mem id.it env.proj_set) && not (can_optimize wfdef env) -> + ([((e, e.note), filter_iter_quants e iterexps)], true) | CaseE _ | StrE _ -> ([((e, e.note), filter_iter_quants e iterexps)], false) | IterE (e1, ((_, id_exp_pairs) as iterexp)) -> - let c1 = create_collector iterexps in - let c2 = create_collector (iterexp :: iterexps) in + let c1 = create_collector wfdef env iterexps in + let c2 = create_collector wfdef env (iterexp :: iterexps) in (collect_exp c2 e1 @ List.concat_map (fun (_, exp) -> collect_exp c1 exp) id_exp_pairs, false) | _ -> ([], true) -and collect_userdef_prem iterexps p = +and collect_userdef_prem wfdef env iterexps p = match p.it with | IterPr (p', ((_, id_exp_pairs) as iterexp)) -> - let c1 = create_collector iterexps in - let c2 = create_collector (iterexp :: iterexps) in + let c1 = create_collector wfdef env iterexps in + let c2 = create_collector wfdef env (iterexp :: iterexps) in (collect_prem c2 p' @ List.concat_map (fun (_, exp) -> collect_exp c1 exp) id_exp_pairs, false) | _ -> ([], true) @@ -126,9 +165,11 @@ and t_exp env e = (* Remove every arg but last for family projections *) | CallE (id, args) when StringSet.mem id.it env.proj_set && args <> [] -> CallE (id, [(Lib.List.last args)]) - (* HACK - Change IterE of option with no iteration variable into a OptE *) + (* HACK - Change IterE of option and list with no iteration variable into a OptE *) | IterE (e1, (Opt, [])) -> - OptE (Some e1) + OptE (Some e1) + | IterE (e1, (List, [])) | IterE (e1, (List1, [])) -> + ListE [e1] | exp -> exp ) $$ e.at % e.note @@ -164,6 +205,7 @@ let needs_wfness env def = | _ -> false let rec get_wf_pred env (exp, t) = + let get_id iter exp = match exp.it with | VarE id -> id @@ -205,19 +247,21 @@ let get_exp_typ q = | ExpP (id, typ) -> Some (VarE id $$ id.at % typ, typ) | _ -> None -let generate_well_formed_rel_hint at: hint = { hintid = wf_hint_id $ at; hintexp = El.Ast.SeqE [] $ at} +let generate_well_formed_rel_hint id at: hint = { hintid = wf_hint_id $ at; hintexp = El.Ast.VarE (id, []) $ at} +let generate_well_formed_func_hint at: hint = { hintid = wf_func_id $ at; hintexp = El.Ast.SeqE [] $ at} +let generate_well_formed_rel_lemma_hint at: hint = { hintid = wf_rel_id $ at; hintexp = El.Ast.SeqE [] $ at} let create_well_formed_predicate env id inst = let tf = { base_transformer with transform_exp = t_exp env; transform_typ = t_typ} in let at = id.at in let user_typ = VarT(id, []) $ at in - let new_mixop pairs = Xl.Mixop.(Seq (List.init (List.length pairs + 1) (fun _ -> Arg ()))) in let create_pairs quants = List.split (List.filter_map (fun b -> match b.it with | ExpP (id', typ) -> Some (("_" $ id'.at, typ), (id', typ)) | _ -> None ) quants) in let tupt pairs = TupT (pairs @ [("_" $ at, user_typ)]) $ at in - let hint = HintD (RelH (wf_pred_prefix ^ id.it $ id.at, [generate_well_formed_rel_hint at]) $ at) $ at in + let new_mixop pairs = Xl.Mixop.(Seq (List.init (List.length pairs + 1) (fun _ -> Arg ()))) in + let hint = HintD (RelH (wf_pred_prefix ^ id.it $ id.at, [generate_well_formed_rel_hint id at]) $ at) $ at in match inst.it with (* Variant well formedness predicate creation *) | InstD (quants, _args, {it = VariantT typcases; _}) -> @@ -283,34 +327,56 @@ let create_well_formed_predicate env id inst = [relation; hint] | _ -> [] -let get_extra_prems env quants exp prems = - if deactivate_wfness then [] else - let cl = create_collector [] in - let wf_terms = collect_exp cl exp @ List.concat_map (collect_prem cl) prems in - let unique_terms = Util.Lib.List.nub (fun ((e1, _t1), iterexp1) ((e2, _t2), iterexp2) -> +let get_wf_terms wfdef env cl exp prems = + let is_calle e = match e.it with + | CallE _ -> true + | _ -> false + in + let exp_terms = collect_exp cl exp in + let wf_terms = (if !wf_state = WfMinimal && can_optimize wfdef env then [] else exp_terms) @ List.concat_map (collect_prem cl) prems in + let (call_prems, constr_prems) = List.partition (fun ((e1, _), _) -> is_calle e1) wf_terms in + let unique_func = Util.Lib.List.nub (fun ((e1, _t1), iterexp1) ((e2, _t2), iterexp2) -> Il.Eq.eq_exp e1 e2 && Il.Eq.eq_list Il.Eq.eq_iterexp iterexp1 iterexp2 - ) wf_terms in - - let more_prems = List.concat_map (fun (pair, iterexps) -> + ) in + let filter_terms_func = Lib.List.filter_not (fun ((e1, _), iterexp1) -> + List.exists (fun ((e2, _), iterexp2) -> + Il.Eq.eq_exp e1 e2 && Il.Eq.eq_list Il.Eq.eq_iterexp iterexp1 iterexp2 + ) exp_terms + ) in + match !wf_state with + | WfNone -> ([], []) + | WfMinimal when can_optimize wfdef env -> (call_prems |> unique_func |> filter_terms_func, constr_prems |> unique_func |> filter_terms_func) + | _ -> (unique_func call_prems, unique_func constr_prems) + +let get_extra_prems wfdef env quants exp prems = + let cl = create_collector wfdef env [] in + let unique_call_terms, unique_constr_terms = get_wf_terms wfdef env cl exp prems in + let wf_creation_func = List.concat_map (fun (pair, iterexps) -> List.map (fun prem' -> List.fold_left (fun acc iterexp -> IterPr (acc, iterexp) $ acc.at ) prem' iterexps) (get_wf_pred env pair) - ) unique_terms in + ) in + let call_prems, constr_prems = wf_creation_func unique_call_terms, wf_creation_func unique_constr_terms in - (* Leverage the fact that the wellformed predicates are "bubbled up" and remove unnecessary wf preds*) - let free_vars = (Free.free_list Free.free_prem more_prems).varid in - let quants_filtered = Lib.List.filter_not (fun q -> match q.it with - | ExpP (id, _) -> Free.Set.mem id.it free_vars + (* Leverage the fact that the wellformed predicates are "bubbled up" and remove unnecessary wf preds *) + let free_vars_exp = (Free.free_exp exp).varid in + let free_vars = (Free.free_list Free.free_prem constr_prems).varid in + let quants_filtered = Lib.List.filter_not (fun b -> + match b.it, !wf_state with + | ExpP (id, _), WfMinimal when can_optimize wfdef env -> + Free.Set.mem id.it free_vars || Free.Set.mem id.it free_vars_exp + | ExpP (id, _), WfMinimal + | ExpP (id, _), WfAll -> Free.Set.mem id.it free_vars | _ -> true ) quants in let quant_prems = (List.filter_map get_exp_typ quants_filtered) |> List.concat_map (get_wf_pred env) in - quant_prems @ more_prems + quant_prems @ call_prems @ constr_prems -let t_rule env rule = +let t_rule rid env rule = let tf = { base_transformer with transform_exp = t_exp env; transform_typ = t_typ} in (match rule.it with | RuleD (id, quants, m, exp, prems) -> - let extra_prems = get_extra_prems env quants exp prems in + let extra_prems = get_extra_prems (Rel rid) env quants exp prems in RuleD (id, List.map (transform_param tf) quants, m, @@ -326,7 +392,7 @@ let t_clause env clause = let free_args = Free.free_list Free.free_arg args in (* Only focus on generating wf preds for variables not in the arguments *) let filtered_quants = Lib.List.filter_not (is_part_of_quant free_args) quants in - let extra_prems = get_extra_prems env filtered_quants exp prems in + let extra_prems = get_extra_prems Func env filtered_quants exp prems in DefD (List.map (transform_param tf) quants, List.map (transform_arg tf) args, transform_exp tf exp, @@ -358,6 +424,98 @@ let remove_unused_params def = { def with it = DecD (id, params', typ, clauses') } | _ -> def +let rec return_type_needs_wfness env (rt : typ) : bool = + let rt' = Utils.reduce_type_aliasing env.il_env rt in + match rt'.it with + | VarT (id, _) -> StringSet.mem id.it env.wf_set + | TupT tups -> tups |> List.map snd |> List.exists (return_type_needs_wfness env) + | IterT (t, _) -> return_type_needs_wfness env t + | _ -> false + +(* HACK: Lemma is actually represented as a relation *) +let generate_wf_lemma_func env tf id params rtyp = + let lemma_name = id.it ^ wf_lemma_suffix in + let params' = Utils.improve_ids_params params in + let wf_prems = List.concat_map (fun p -> match p.it with + | ExpP (id, typ) -> get_wf_pred env (VarE id $$ id.at % typ, typ) + | _ -> [] + ) params' in + let ids = List.map Utils.get_param_id params in + let text_ids = List.map (fun p -> p.it) ids in + let ret_exp_name = Utils.annot_new_name (Utils.generate_var text_ids "ret_val") rtyp in + let ret_exp = VarE (ret_exp_name $ id.at) $$ id.at % rtyp in + let fcall_exp = CallE (id, List.map make_arg params') $$ id.at % rtyp in + let fcall_prem = IfPr (CmpE (`EqOp, `BoolT, ret_exp, fcall_exp) $$ id.at % (BoolT $ id.at)) $ id.at in + let wf_conclusion = get_wf_pred env (ret_exp, rtyp) in + + let ret_param = ExpP (ret_exp_name $ id.at, rtyp) $ id.at in + let new_quants = params' @ [ret_param] in + + let fixed, not_fixed = List.partition_map (fun p -> match p.it with + | ExpP (id', typ) -> Right (VarE id' $$ id'.at % typ) + | _ -> Left p + ) params' + in + let typtups = List.filter_map (fun p -> match p.it with + | ExpP (id', typ) -> Some (id', typ) + | _ -> None + ) params' + in + let tupt = TupT (typtups @ [(ret_exp_name $ id.at, ret_exp.note)]) $ id.at in + let tupe = TupE (not_fixed @ [ret_exp]) $$ id.at % tupt in + let new_mixop = Xl.Mixop.(Seq (List.init (List.length not_fixed + 1) (fun _ -> Arg ()))) in + let rule = RuleD ( + lemma_name ^ "_0" $ id.at, + new_quants, + new_mixop, + tupe, + wf_prems @ [fcall_prem] @ wf_conclusion + ) $ id.at + in + let hint = HintD (RelH (lemma_name $ id.at, [generate_well_formed_func_hint id.at]) $ id.at) $ id.at in + let relation = RelD (lemma_name $ id.at, + List.map (transform_param tf) fixed, new_mixop, + transform_typ tf tupt, + [transform_rule tf rule]) $ id.at in + [hint; relation] + +let generate_wf_lemma_rel env mop tf id params typ modemap = + let typs = match typ.it with + | TupT typs' -> List.mapi (fun i (tid, t) -> + let new_id = "var_" ^ Int.to_string i in + if tid.it = "_" then (new_id $ tid.at, t) else (tid, t)) typs' + | _ -> ["var_0" $ no_region, typ] + in + let lemma_name = id.it ^ wf_lemma_suffix in + assert (List.length typs = Hints.IntMap.cardinal modemap); + let elements = Hints.IntMap.bindings modemap in + let quants, typs' = Utils.improve_ids_quants [] true id.at typs in + let exps = List.map (fun (id', t) -> VarE id' $$ id'.at % t) typs' in + let ins, outs = + List.map2 (fun (id', t) (_, mode) -> + ((VarE id' $$ id'.at % t, t), mode) + ) typs' elements |> + List.partition_map (fun (t, mode) -> match mode with + | Hints.In -> Left t + | Hints.Out -> Right t + ) in + let tupt = TupT (typs') $ id.at in + let tupe = TupE exps $$ id.at % tupt in + let wf_inputs = List.concat_map (get_wf_pred env) ins in + let rel_pr = RulePr (id, List.map make_arg params, mop, tupe) $ id.at in + let wf_outputs = List.concat_map (get_wf_pred env) outs in + let new_mixop = Xl.Mixop.(Seq (List.init (List.length quants) (fun _ -> Arg ()))) in + if outs = [] || wf_outputs = [] then [] else (* No need to generate lemma for bool outputs *) + let rule = RuleD (lemma_name ^ "_0" $ id.at, params @ quants, new_mixop, tupe, wf_inputs @ [rel_pr] @ wf_outputs) $ id.at in + let hint = HintD (RelH (lemma_name $ id.at, [generate_well_formed_rel_lemma_hint id.at]) $ id.at) $ id.at in + let relation = + RelD (lemma_name $ id.at, + params, + new_mixop, + tupt, + [rule]) $ id.at in + [hint; transform_def tf relation] + let rec t_def env def = let tf = { base_transformer with transform_exp = t_exp env; transform_typ = t_typ } in match def.it with @@ -369,7 +527,12 @@ let rec t_def env def = | TypD (_, _, _) -> error def.at "Multiples instances encountered, please run type family removal pass first." | RelD (id, params, m, typ, rules) -> - (RelD (id, List.map (transform_param tf) params |> List.filter is_type_param, m, transform_typ tf typ, List.map (t_rule env) rules) $ def.at, []) + let wf_lemma = + match (Hints.find_opt id.it env.il_hintenv.modes) with + | Some modemap -> generate_wf_lemma_rel env m tf id params typ modemap + | _ -> [] + in + (RelD (id, List.map (transform_param tf) params |> List.filter is_type_param, m, transform_typ tf typ, List.map (t_rule id env) rules) $ def.at, wf_lemma) | DecD (id, params, typ, clauses) -> let d = DecD (id, List.map (transform_param tf) params, @@ -377,8 +540,13 @@ let rec t_def env def = List.map (t_clause env) clauses ) $ def.at in + let is_proj_func = StringSet.mem id.it env.proj_set in let t_d = if StringSet.mem id.it env.proj_set then remove_unused_params d else d in - (t_d, []) + let wf_lemma = if !wf_state = WfMinimal && return_type_needs_wfness env typ && not is_proj_func + then generate_wf_lemma_func env tf id params typ + else [] + in + (t_d, wf_lemma) | GramD (id, params, typ, prods) -> (GramD (id, List.map (transform_param tf) params, transform_typ tf typ, List.map (transform_prod tf) prods) $ def.at, []) | RecD defs -> @@ -389,24 +557,25 @@ let rec t_def env def = if List.concat wf_relations = [] then (rec_defs, []) else (rec_defs, [RecD (List.concat wf_relations) $ def.at]) | HintD hintdef -> (HintD hintdef $ def.at, []) - let has_proj_hint (hint : hint) = hint.hintid.it = Typefamilyremoval.projection_hint_id +let has_tf_hint (hint : hint) = hint.hintid.it = Typefamilyremoval.type_family_hint_id +let has_wfopt_hint (hint : hint) = hint.hintid.it = wf_opt_id -let create_proj_map_def set (d : def) = +let create_hints env (d : def) = match d.it with - | HintD {it = DecH (id, hints); _} -> - (match (List.find_opt has_proj_hint hints) with - | Some _ -> set := StringSet.add id.it !set - | _ -> () - ) + | HintD {it = DecH (id, hints); _} when List.exists has_proj_hint hints -> + env.proj_set <- StringSet.add id.it env.proj_set + | HintD {it = TypH (id, hints); _} when List.exists has_tf_hint hints -> + env.tf_set <- StringSet.add id.it env.tf_set + | HintD {it = RelH (id, hints); _} when List.exists has_wfopt_hint hints -> + env.wfopt_set <- StringSet.add id.it env.wfopt_set | _ -> () - + let transform (il : script): script = let env = empty () in env.il_env <- Il.Env.env_of_script il; - let proj_set = ref StringSet.empty in - List.iter (create_proj_map_def proj_set) il; - env.proj_set <- !proj_set; + List.iter (create_hints env) il; + env.il_hintenv <- Hints.build_il_hints error il; List.concat_map (fun d -> let (t_d, wf_relations) = t_def env d in t_d :: wf_relations diff --git a/spectec/src/middlend/undep.mli b/spectec/src/middlend/undep.mli index b19733d32c..87492a3b9a 100644 --- a/spectec/src/middlend/undep.mli +++ b/spectec/src/middlend/undep.mli @@ -40,5 +40,13 @@ This pass requires the typefamilyremoval pass to be ran first, as it ensures tha transformed correctly. *) +type wfstate = + | WfAll (* Places wf premises whenever it encounters a term/variable that needs well-formedness check*) + | WfMinimal (* Places only wf premises in terms in relations and functions that do not appear in the conclusion *) + | WfNone (* Does not place any wf premises in relations/functions *) + val wf_hint_id : string -val transform : Il.Ast.script -> Il.Ast.script \ No newline at end of file +val wf_func_id : string +val wf_rel_id : string +val wf_state : wfstate ref +val transform : Il.Ast.script -> Il.Ast.script diff --git a/spectec/src/middlend/utils.ml b/spectec/src/middlend/utils.ml index 2096591915..d325e53135 100644 --- a/spectec/src/middlend/utils.ml +++ b/spectec/src/middlend/utils.ml @@ -31,6 +31,13 @@ and reduce_inst_alias env args inst base_typ = ) | _ -> base_typ +let is_part_of_quant (free_set : Free.sets) b = + match b.it with + | ExpP (id, _) -> Free.Set.mem id.it free_set.varid + | TypP id -> Free.Set.mem id.it free_set.typid + | DefP (id, _, _) -> Free.Set.mem id.it free_set.defid + | GramP (id, _, _) -> Free.Set.mem id.it free_set.gramid + let generate_var ids id = let start = 0 in let fresh_prefix = "var" in @@ -47,6 +54,16 @@ let generate_var ids id = | s when List.mem s ids -> go s start | _ -> id +let rec annot_new_name name t = + match t.it with + | IterT (t', iter) -> + assert (iter = List || iter = Opt); + annot_new_name name t' ^ Il.Print.string_of_iter iter + | _ -> name + +let annot_name old_name name t = + if name = old_name then name else annot_new_name name t + let improve_ids_quants ids generate_all_quants at exp_typ_pairs = let rec improve_ids_helper ids qs = match qs with @@ -54,10 +71,10 @@ let improve_ids_quants ids generate_all_quants at exp_typ_pairs = | (q_id, t) :: qs' -> let new_name = generate_var ids q_id.it in let (quants, pairs) = improve_ids_helper (new_name :: ids) qs' in - let new_pairs = (new_name $ q_id.at, t) :: pairs in + let new_pairs = (annot_name q_id.it new_name t $ q_id.at, t) :: pairs in if not generate_all_quants && new_name = q_id.it then (quants, new_pairs) - else ((ExpP (new_name $ q_id.at, t) $ at) :: quants, new_pairs) + else ((ExpP (annot_name q_id.it new_name t $ q_id.at, t) $ at) :: quants, new_pairs) in improve_ids_helper ids exp_typ_pairs @@ -68,7 +85,7 @@ let get_param_id p = let improve_ids_params params = let reconstruct_param id p = (match p.it with - | ExpP (_, t) -> ExpP (id, t) + | ExpP (_, t) -> ExpP (annot_new_name id.it t $ id.at, t) | TypP _ -> TypP id | DefP (_, params, r_typ) -> DefP (id, params, r_typ) | GramP (_, params, r_typ) -> GramP (id, params, r_typ) @@ -80,7 +97,9 @@ let improve_ids_params params = | p :: ps' -> let p_id = get_param_id p in let new_name = generate_var ids p_id.it $ p_id.at in - reconstruct_param new_name p :: improve_ids_helper (new_name.it :: ids) ps' + if p_id.it = new_name.it + then p :: improve_ids_helper (p_id.it :: ids) ps' + else reconstruct_param new_name p :: improve_ids_helper (new_name.it :: ids) ps' in improve_ids_helper [] params diff --git a/spectec/test-middlend/dune.inc b/spectec/test-middlend/dune.inc index c0e1be3143..0b72d966ba 100644 --- a/spectec/test-middlend/dune.inc +++ b/spectec/test-middlend/dune.inc @@ -7,8 +7,10 @@ (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/06-else.il specification.act/06-else.il)))) (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/07-else-simplification.il specification.act/07-else-simplification.il)))) (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/08-uncase-removal.il specification.act/08-uncase-removal.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/09-sideconditions.il specification.act/09-sideconditions.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/10-sub-expansion.il specification.act/10-sub-expansion.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/09-sub-expansion.il specification.act/09-sub-expansion.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/10-pattern-simp.il specification.act/10-pattern-simp.il)))) (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/11-sub.il specification.act/11-sub.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/12-alias-demut.il specification.act/12-alias-demut.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/13-improve-ids.il specification.act/13-improve-ids.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/12-definition-to-relation.il specification.act/12-definition-to-relation.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/13-sideconditions.il specification.act/13-sideconditions.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/14-alias-demut.il specification.act/14-alias-demut.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/15-improve-ids.il specification.act/15-improve-ids.il)))) diff --git a/spectec/test-middlend/specification.exp/00-elab.il b/spectec/test-middlend/specification.exp/00-elab.il index 018474390a..426967e6f5 100644 --- a/spectec/test-middlend/specification.exp/00-elab.il +++ b/spectec/test-middlend/specification.exp/00-elab.il @@ -1120,7 +1120,7 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ([], []) diff --git a/spectec/test-middlend/specification.exp/01-ite.il b/spectec/test-middlend/specification.exp/01-ite.il index dabf1a2d2a..bd9bfea3db 100644 --- a/spectec/test-middlend/specification.exp/01-ite.il +++ b/spectec/test-middlend/specification.exp/01-ite.il @@ -1094,7 +1094,7 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ([], []) diff --git a/spectec/test-middlend/specification.exp/02-let-intro-mech.il b/spectec/test-middlend/specification.exp/02-let-intro-mech.il index 63f2fcb8d0..c4e18ddb03 100644 --- a/spectec/test-middlend/specification.exp/02-let-intro-mech.il +++ b/spectec/test-middlend/specification.exp/02-let-intro-mech.il @@ -1094,7 +1094,7 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ([], []) diff --git a/spectec/test-middlend/specification.exp/03-typefamily-removal.il b/spectec/test-middlend/specification.exp/03-typefamily-removal.il index 57ffc3bd71..15185d7d7f 100644 --- a/spectec/test-middlend/specification.exp/03-typefamily-removal.il +++ b/spectec/test-middlend/specification.exp/03-typefamily-removal.il @@ -1094,7 +1094,7 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ([], []) diff --git a/spectec/test-middlend/specification.exp/04-remove-indexed-types.il b/spectec/test-middlend/specification.exp/04-remove-indexed-types.il index b80d15a413..480ae7eacf 100644 --- a/spectec/test-middlend/specification.exp/04-remove-indexed-types.il +++ b/spectec/test-middlend/specification.exp/04-remove-indexed-types.il @@ -308,19 +308,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -371,23 +392,27 @@ def $utf8(char*) : byte* def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] -- if ((128 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 2048)) -- if (ch!`%`_char.0 = (((2 ^ 6) * (((b_1!`%`_byte.0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] -- if (((2048 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 55296)) \/ ((57344 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 65536))) -- if (ch!`%`_char.0 = ((((2 ^ 12) * (((b_1!`%`_byte.0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] -- if ((65536 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 69632)) -- if (ch!`%`_char.0 = (((((2 ^ 18) * (((b_1!`%`_byte.0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $utf8(var_0)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -576,10 +601,18 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { @@ -587,70 +620,162 @@ rec { def $free_list(free*) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) } +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_list(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -665,6 +790,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -1029,73 +1163,157 @@ syntax Cnn = def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1392,7 +1610,15 @@ def $unpack(storagetype : storagetype) : valtype def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype @@ -1424,10 +1650,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype @@ -1463,6 +1697,19 @@ def $globalsxt(externtype*) : globaltype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsxt(var_0)) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 @@ -1476,6 +1723,19 @@ def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsxt(var_0)) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 @@ -1489,6 +1749,19 @@ def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesxt(var_0)) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 def $funcsxt(externtype*) : deftype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 @@ -1513,7 +1786,22 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typevar(typevar, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ([], []) @@ -1522,7 +1810,21 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`}) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) - -- wf_typevar: `%`(_IDX_typevar(x)) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $minus_recs(var_0, var_1)) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1563,7 +1865,6 @@ def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype @@ -1575,7 +1876,6 @@ def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype @@ -1588,25 +1888,20 @@ def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storaget def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype @@ -1620,6 +1915,98 @@ def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typeuse(typeuse, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_heaptype(heaptype, var_0, var_1)) + -- wf_heaptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_reftype(reftype, var_0, var_1)) + -- wf_reftype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_valtype(valtype, var_0, var_1)) + -- wf_valtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_storagetype(storagetype, var_0, var_1)) + -- wf_storagetype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_fieldtype(fieldtype, var_0, var_1)) + -- wf_fieldtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_comptype(comptype, var_0, var_1)) + -- wf_comptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_subtype(subtype, var_0, var_1)) + -- wf_subtype: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1634,97 +2021,204 @@ def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_globaltype(globaltype, var_0, var_1)) + -- wf_globaltype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_tabletype(tabletype, var_0, var_1)) + -- wf_tabletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_externtype(externtype, var_0, var_1)) + -- wf_externtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_moduletype(moduletype, var_0, var_1)) + -- wf_moduletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $free_moduletype(moduletype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = | mk_num__0(Inn : Inn, var_x : iN) @@ -2447,7 +3174,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4191,22 +4926,45 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`((consttype : consttype <: storagetype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4214,6 +4972,15 @@ def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $free_blocktype(blocktype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4225,6 +4992,15 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { @@ -4236,7 +5012,6 @@ def $shift_labelidxs(labelidx*) : labelidx* def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4246,13 +5021,10 @@ rec { def $free_instr(instr : instr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 @@ -4283,7 +5055,6 @@ def $free_instr(instr : instr) : free def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 @@ -4294,7 +5065,6 @@ def $free_instr(instr : instr) : free def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 @@ -4357,13 +5127,10 @@ def $free_instr(instr : instr) : free def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 @@ -4372,10 +5139,8 @@ def $free_instr(instr : instr) : free def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 @@ -4400,7 +5165,6 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 @@ -4411,10 +5175,8 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 @@ -4473,11 +5235,42 @@ def $free_block(instr*) : free -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) } +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = $free_instr(instr)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_block(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr(expr : expr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = $free_expr(expr)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = | ACTIVE(tableidx : tableidx, expr : expr) @@ -4668,85 +5461,216 @@ def $free_type(type : type) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free}: + `%%`(type, ret_val) + -- if (ret_val = $free_type(type)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag(tag : tag) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = $free_tag(tag)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global(global : global) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = $free_global(global)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table(table : table) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = $free_table(table)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local(local : local) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = $free_local(local)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func(func : func) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = $free_func(func)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(datamode : datamode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = $free_datamode(datamode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data(data : data) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_data_is_wf: `%%`(data : data, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_data_is_wf_0{data : data, ret_val : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = $free_data(data)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(elemmode : elemmode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = $free_elemmode(elemmode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem(elem : elem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elem_is_wf_0{elem : elem, ret_val : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = $free_elem(elem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import(import : import) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = $free_import(import)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module(module : module) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = $free_module(module)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $funcidx_module(module : module) : funcidx* ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec @@ -4830,6 +5754,21 @@ def $with_locals(context : context, localidx*, localtype*) : context ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $with_locals(context, var_0, var_1)) + -- wf_context: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 def $clos_deftypes(deftype*) : deftype* ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 @@ -4845,6 +5784,16 @@ def $clos_valtype(context : context, valtype : valtype) : valtype def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $clos_valtype(context, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_deftype(context : context, deftype : deftype) : deftype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -4863,12 +5812,32 @@ def $clos_externtype(context : context, externtype : externtype) : externtype def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = $clos_externtype(context, externtype)) + -- wf_externtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype(context : context, moduletype : moduletype) : moduletype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $clos_moduletype(context, moduletype)) + -- wf_moduletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -4914,6 +5883,7 @@ relation Expand: `%~~%`(deftype, comptype) rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: `%~~%`(deftype, comptype) -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`($unrolldt(deftype)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -4939,6 +5909,16 @@ def $unrollht_(context : context, heaptype : heaptype) : subtype ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = $unrollht_(context, heaptype)) + -- wf_subtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5090,6 +6070,7 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrollht_(C, (typeuse : typeuse <: heaptype))))*{typeuse <- `typeuse*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} @@ -5161,6 +6142,7 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) -- wf_context: `%`(C) + -- wf_subtype: `%`($unrolldt(deftype_1)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5495,6 +6477,7 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrolldt(C.TYPES_context[x!`%`_uN.0])))*{x <- `x*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} @@ -5621,6 +6604,7 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- (if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -5793,19 +6777,24 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(VCONST_val(Vnn, `%`_vec_(0))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(`REF.NULL_ADDR`_val) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?() +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $default_(valtype)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -5813,6 +6802,7 @@ relation Defaultable: `|-%DEFAULTABLE`(valtype) `|-%DEFAULTABLE`(t) -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- $default_(t)} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -5979,6 +6969,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) @@ -6190,6 +7181,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6232,6 +7224,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6262,6 +7255,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6330,6 +7324,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6779,6 +7774,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if (i!`%`_uN.0 < (2 * $dim(sh!`%`_bshape.0)!`%`_dim.0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh!`%`_bshape.0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -6794,6 +7790,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) @@ -6802,6 +7799,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) @@ -6857,6 +7855,7 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -6902,6 +7901,7 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) `|-%NONDEFAULTABLE`(t) -- if ($default_(t) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- $default_(t)} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7035,6 +8035,7 @@ relation Tag_ok: `%|-%:%`(context, tag, tagtype) `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`($clos_tagtype(C, tagtype)) -- wf_tag: `%`(TAG_tag(tagtype)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7182,6 +8183,7 @@ relation Import_ok: `%|-%:%`(context, import, externtype) `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`($clos_externtype(C, xt)) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7297,7 +8299,6 @@ relation wf_nonfuncs: `%`(nonfuncs) def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -7327,6 +8328,12 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`($clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + -- (wf_uN: `%%`(32, iter))*{iter <- $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))} + -- (wf_typeuse: `%`(iter))*{iter <- $tagsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_globaltype: `%`(iter))*{iter <- $globalsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_memtype: `%`(iter))*{iter <- $memsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_tabletype: `%`(iter))*{iter <- $tablesxt(xt_I*{xt_I <- `xt_I*`})} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7370,81 +8377,272 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $signed_(N : N, nat : nat) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7474,10 +8672,16 @@ def $sx(storagetype : storagetype) : sx? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7506,7 +8710,6 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN @@ -7526,28 +8729,23 @@ def $ipopcnt_(N : N, iN : iN) : iN def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN((i!`%`_uN.0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN((i!`%`_uN.0 \ (2 ^ M)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7555,7 +8753,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7563,7 +8760,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? -- if ((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7571,13 +8767,11 @@ def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) -- if ((j_1 = $signed_(N, i_1!`%`_uN.0)) /\ (j_2 = $signed_(N, i_2!`%`_uN.0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7605,19 +8799,15 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7668,140 +8858,323 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* +def $fsqrt_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* +def $fceil_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* +def $ffloor_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* +def $ftrunc_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* +def $fnearest_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* +def $fadd_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +def $fsub_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +def $fmul_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 +def $fdiv_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 +def $fmin_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fge_(N : N, fN : fN, fN : fN) : u32 +def $fmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmin_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fcopysign_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $feq_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fne_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $flt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fgt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fle_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -7820,26 +9193,69 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7847,7 +9263,16 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(($cunpack(storagetype) : consttype <: storagetype), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -7855,7 +9280,15 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7863,103 +9296,103 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`(($cunpack((packtype : packtype <: storagetype)) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(($cunpack(storagetype) : consttype <: storagetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $unop_(numtype, unop_, num_)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = $binop_(numtype, binop_, num_, num__0)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -7997,37 +9430,48 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $cvtop__(numtype_1, numtype_2, cvtop__, num_)) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ @@ -8072,13 +9516,11 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else (if ($signed_(N, i!`%`_uN.0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[(i!`%`_uN.0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* @@ -8087,7 +9529,6 @@ def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* @@ -8106,7 +9547,6 @@ def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8116,7 +9556,6 @@ def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, s -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8168,7 +9607,6 @@ def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8179,7 +9617,6 @@ def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8190,8 +9627,6 @@ def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} @@ -8202,7 +9637,6 @@ def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : v -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ @@ -8211,7 +9645,6 @@ def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : i -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 @@ -8219,7 +9652,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)))*{c_1 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -8232,7 +9664,6 @@ def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ @@ -8268,175 +9699,136 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = $lcvtop__(shape_1, shape_2, vcvtop__, lane_)) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ @@ -8446,7 +9838,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8455,7 +9846,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8464,7 +9854,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) @@ -8472,31 +9861,25 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8517,8 +9900,6 @@ def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = i!`%`_uN.0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ @@ -8527,32 +9908,24 @@ def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8563,8 +9936,6 @@ def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : i -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8576,22 +9947,10 @@ def $ivmul_(N : N, iN*, iN*) : iN* def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ @@ -8602,7 +9961,6 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -8962,7 +10320,16 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = (val : val <: fieldval) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i)) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = $packfield_(storagetype, val)) + -- wf_fieldval: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val @@ -8970,7 +10337,16 @@ def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = val ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $unpackfield_(storagetype, var_0, fieldval)) + -- wf_val: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -9042,11 +10418,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9057,61 +10451,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9122,123 +10624,337 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[x!`%`_uN.0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) + def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst @@ -9249,10 +10965,19 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst -- if (i'!`%`_uN.0 = (|r'*{r' <- `r'*`}| + n)) -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} -- if ((i'!`%`_uN.0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = $growtable(tableinst, nat, ref)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem(meminst : meminst, nat : nat) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9262,10 +10987,18 @@ def $growmem(meminst : meminst, nat : nat) : meminst -- if ((i'!`%`_uN.0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} -- if (i'!`%`_uN.0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $growmem(meminst, nat)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -9471,26 +11204,76 @@ def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $inst_valtype(moduleinst, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = $inst_reftype(moduleinst, reftype)) + -- wf_reftype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = $inst_globaltype(moduleinst, globaltype)) + -- wf_globaltype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $inst_memtype(moduleinst, memtype)) + -- wf_memtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = $inst_tabletype(moduleinst, tabletype)) + -- wf_tabletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -9829,6 +11612,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) -- if (c <- $unop_(nt, unop, c_1)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -9837,6 +11621,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) -- if ($unop_(nt, unop, c_1) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) @@ -9845,6 +11630,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9854,6 +11640,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) -- if ($binop_(nt, binop, c_1, c_2) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9863,6 +11650,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9871,6 +11659,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) @@ -9880,6 +11669,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) @@ -9888,6 +11678,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) @@ -9896,6 +11687,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -9904,6 +11696,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -9913,6 +11706,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -9923,6 +11717,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9931,6 +11726,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vunop_(sh, vunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -9939,6 +11735,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) -- if ($vunop_(sh, vunop, c_1) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) @@ -9947,6 +11744,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -9956,6 +11754,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -9965,6 +11764,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -9975,6 +11775,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -9987,6 +11788,8 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) -- if (!($proj_num__0(c))!`%`_uN.0 = $prod($inez_($jsizenn(Jnn), !($proj_lane__2(i)))!`%`_uN.0*{i <- `i*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9996,6 +11799,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- wf_uN: `%%`(128, $vrelop_(sh, vrelop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) @@ -10005,6 +11809,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- wf_uN: `%%`(128, $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) @@ -10014,6 +11819,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, $vbitmaskop_(sh, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10022,6 +11828,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- wf_uN: `%%`(128, $vswizzlop_(sh, swizzlop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) @@ -10031,6 +11838,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- wf_uN: `%%`(128, $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) @@ -10040,6 +11848,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10049,6 +11859,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -10059,6 +11870,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -10068,6 +11881,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -10078,6 +11894,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- wf_uN: `%%`(128, $vextunop__(sh_1, sh_2, vextunop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10086,6 +11903,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- wf_uN: `%%`(128, $vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) @@ -10095,6 +11913,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- wf_uN: `%%`(128, $vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10105,6 +11924,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) + -- wf_uN: `%%`(128, $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) @@ -10114,6 +11934,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- wf_uN: `%%`(128, $vcvtop__(sh_1, sh_2, vcvtop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10123,11 +11944,19 @@ def $blocktype_(state : state, blocktype : blocktype) : instrtype ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $blocktype_(state, blocktype)) + -- wf_instrtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read: `%~>%`(config, instr*) @@ -10135,6 +11964,7 @@ relation Step_read: `%~>%`(config, instr*) rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10143,6 +11973,7 @@ relation Step_read: `%~>%`(config, instr*) rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10151,6 +11982,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -10164,6 +11996,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10177,6 +12010,7 @@ relation Step_read: `%~>%`(config, instr*) rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10194,6 +12028,7 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ $default_(t)*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) @@ -10204,6 +12039,7 @@ relation Step_read: `%~>%`(config, instr*) rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10230,6 +12066,7 @@ relation Step_read: `%~>%`(config, instr*) rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) @@ -10276,6 +12113,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10285,6 +12123,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10313,6 +12152,7 @@ relation Step_read: `%~>%`(config, instr*) rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10322,6 +12162,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10329,12 +12170,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10342,6 +12185,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[!($proj_num__0(i))!`%`_uN.0] : ref <: instr)]) -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10349,6 +12193,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -10357,6 +12202,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10382,6 +12228,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10425,6 +12273,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10439,6 +12289,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) -- otherwise + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -10451,6 +12302,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10458,6 +12310,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -10465,6 +12319,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10472,6 +12327,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) @@ -10479,6 +12336,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10486,6 +12344,8 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10493,6 +12353,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10501,6 +12362,9 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) rule `vload-splat-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10520,6 +12385,9 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -10529,6 +12397,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10538,6 +12407,9 @@ relation Step_read: `%~>%`(config, instr*) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10545,6 +12417,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) @@ -10555,6 +12428,10 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -10565,6 +12442,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -10573,6 +12451,7 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10598,6 +12477,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10641,6 +12522,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10680,6 +12563,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -10694,6 +12578,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10709,6 +12594,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (if ($default_($unpack(zt)) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- $default_($unpack(zt))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -10723,6 +12610,8 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0]) : val <: instr)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0])) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -10732,6 +12621,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($default_($unpack(zt)) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $default_($unpack(zt))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10740,6 +12631,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10748,6 +12640,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[!($proj_num__0(i))!`%`_uN.0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -10756,6 +12649,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(i))!`%`_uN.0 + ((((n * $zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10766,6 +12660,11 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, ((($zsize(zt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[!($proj_num__0(i))!`%`_uN.0 : ((((n * $zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const($cunpack(zt), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`(($cunpack(zt) : consttype <: storagetype), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, ((($zsize(zt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10780,6 +12679,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) @@ -10787,6 +12687,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0]) : val <: instr)]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0])) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10812,6 +12714,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10850,6 +12753,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10857,6 +12761,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10915,6 +12820,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10922,6 +12828,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10938,6 +12845,7 @@ relation Step_read: `%~>%`(config, instr*) -- otherwise -- if (ref = $elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -10957,6 +12865,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10965,6 +12874,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * $zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10983,6 +12893,10 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0 : ((($zsize(zt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const($cunpack(zt), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`(($cunpack(zt) : consttype <: storagetype), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11055,6 +12969,8 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`($as_deftype($tag(z, x).TYPE_taginst), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) -- if (exn = {TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) @@ -11076,6 +12992,7 @@ relation Step: `%~>%`(config, config) rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11083,6 +13000,7 @@ relation Step: `%~>%`(config, config) rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) @@ -11090,6 +13008,8 @@ relation Step: `%~>%`(config, config) rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) -- if (ti = $growtable($table(z, x), n, ref)) + -- wf_tableinst: `%`($growtable($table(z, x), n, ref)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) @@ -11109,6 +13029,7 @@ relation Step: `%~>%`(config, config) rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11116,6 +13037,7 @@ relation Step: `%~>%`(config, config) rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11123,6 +13045,7 @@ relation Step: `%~>%`(config, config) rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11130,6 +13053,8 @@ relation Step: `%~>%`(config, config) rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11137,6 +13062,7 @@ relation Step: `%~>%`(config, config) rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11144,6 +13070,7 @@ relation Step: `%~>%`(config, config) rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11151,6 +13078,7 @@ relation Step: `%~>%`(config, config) rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11160,6 +13088,7 @@ relation Step: `%~>%`(config, config) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0)) @@ -11168,6 +13097,8 @@ relation Step: `%~>%`(config, config) rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) -- if (mi = $growmem($mem(z, x), n)) + -- wf_meminst: `%`($growmem($mem(z, x), n)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) @@ -11189,6 +13120,7 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) -- if (si = {TYPE $type(z, x), FIELDS $packfield_(zt, val)^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11213,6 +13145,7 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS $packfield_(zt, val)^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11228,6 +13161,7 @@ relation Step: `%~>%`(config, config) rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11290,9 +13224,18 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = $alloctag(store, tagtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11306,14 +13249,38 @@ def $alloctags(store : store, tagtype*) : (store, tagaddr*) -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $alloctags(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = $allocglobal(store, globaltype, val)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11327,14 +13294,38 @@ def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $allocglobals(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $allocmem(store, memtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11348,14 +13339,38 @@ def $allocmems(store : store, memtype*) : (store, memaddr*) -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocmems(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = $alloctable(store, tabletype, ref)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11369,14 +13384,39 @@ def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $alloctables(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = $allocfunc(store, deftype, funccode, moduleinst)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11390,14 +13430,38 @@ def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funca -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = $allocfuncs(store, var_0, var_1, var_2)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocdata(store, datatype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11411,14 +13475,38 @@ def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocdatas(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocelem(store, elemtype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11432,29 +13520,59 @@ def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocelems(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -11483,8 +13601,6 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[x!`%`_uN.0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -11496,16 +13612,36 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = $allocmodule(store, module, var_0, var_1, var_2, var_3)) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_(dataidx : dataidx, data : data) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = $rundata_(dataidx, data)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_(elemidx : elemidx, elem : elem) : instr* @@ -11513,13 +13649,18 @@ def $runelem_(elemidx : elemidx, elem : elem) : instr* def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = $runelem_(elemidx, elem)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11532,13 +13673,27 @@ def $evalexprs(state : state, expr*) : (state, ref*) def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) -- wf_state: `%`(z') } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprs(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 @@ -11552,6 +13707,21 @@ def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprss(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 def $evalglobals(state : state, globaltype*, expr*) : (state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 @@ -11562,12 +13732,27 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- let{s : store, f : frame} `%;%`_state(s, f) = z' -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $evalglobals(state, var_0, var_1)) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate(store : store, module : module, externaddr*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -11591,7 +13776,6 @@ def $instantiate(store : store, module : module, externaddr*) : config -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -11606,15 +13790,34 @@ def $instantiate(store : store, module : module, externaddr*) : config -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = $instantiate(store, module, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke(store : store, funcaddr : funcaddr, val*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $invoke(store, funcaddr, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -11633,6 +13836,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -11677,11 +13888,23 @@ rec { def $concat_idctxt(idctxt*) : idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) } +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $concat_idctxt(var_0)) + -- wf_idctxt: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec relation Idctxt_ok: `|-%:OK`(idctxt) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -11700,6 +13923,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -11814,6 +14048,19 @@ def $importsd(decl*) : import* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $importsd(var_0)) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 @@ -11827,6 +14074,19 @@ def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tagsd(var_0)) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 @@ -11840,6 +14100,19 @@ def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsd(var_0)) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 @@ -11853,6 +14126,19 @@ def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsd(var_0)) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 @@ -11866,6 +14152,19 @@ def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesd(var_0)) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 @@ -11879,6 +14178,19 @@ def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $funcsd(var_0)) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 @@ -11892,6 +14204,19 @@ def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $datasd(var_0)) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 @@ -11905,6 +14230,19 @@ def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $elemsd(var_0)) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 @@ -11918,6 +14256,19 @@ def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $startsd(var_0)) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 def $exportsd(decl*) : export* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 @@ -11928,6 +14279,19 @@ def $exportsd(decl*) : export* def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) } +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $exportsd(var_0)) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} +} + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $ordered(decl*) : bool ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12133,6 +14497,7 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -12603,6 +14968,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -12628,6 +15001,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -12641,6 +15023,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -15005,7 +17400,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -15076,7 +17471,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -15085,7 +17480,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec diff --git a/spectec/test-middlend/specification.exp/05-totalize.il b/spectec/test-middlend/specification.exp/05-totalize.il deleted file mode 100644 index f82c000d09..0000000000 --- a/spectec/test-middlend/specification.exp/05-totalize.il +++ /dev/null @@ -1,16385 +0,0 @@ - -;; ../../../../specification/wasm-3.0/0.1-aux.vars.spectec -syntax N = nat - -;; ../../../../specification/wasm-3.0/0.1-aux.vars.spectec -syntax M = nat - -;; ../../../../specification/wasm-3.0/0.1-aux.vars.spectec -syntax K = nat - -;; ../../../../specification/wasm-3.0/0.1-aux.vars.spectec -syntax n = nat - -;; ../../../../specification/wasm-3.0/0.1-aux.vars.spectec -syntax m = nat - -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec -def $min(nat : nat, nat : nat) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec - def $min{i : nat, j : nat}(i, j) = (if (i <= j) then i else j) - -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.1-9.56 -def $sum(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:10.1-10.18 - def $sum([]) = 0 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:11.1-11.35 - def $sum{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n + $sum(n'*{n' <- `n'*`})) -} - -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.1-13.57 -def $prod(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:14.1-14.19 - def $prod([]) = 1 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:15.1-15.37 - def $prod{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n * $prod(n'*{n' <- `n'*`})) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -def $opt_(syntax X, X*) : X?? - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $opt_{syntax X}(syntax X, []) = ?(?()) - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $opt_{syntax X, w : X}(syntax X, [w]) = ?(?(w)) - def $opt_{syntax X, x1 : X*}(syntax X, x1) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:14.1-14.82 -def $concat_(syntax X, X**) : X* - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:15.1-15.34 - def $concat_{syntax X}(syntax X, []) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:16.1-16.64 - def $concat_{syntax X, `w*` : X*, `w'**` : X**}(syntax X, [w*{w <- `w*`}] ++ w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) = w*{w <- `w*`} ++ $concat_(syntax X, w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:18.1-18.89 -def $concatn_(syntax X, X**, nat : nat) : X* - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 - def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w^n{w <- `w*`}] ++ w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -def $concatopt_(syntax X, X?*) : X* - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $concatopt_{syntax X}(syntax X, []) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $concatopt_{syntax X, `w?` : X?, `w'?*` : X?*}(syntax X, [w?{w <- `w?`}] ++ w'?{w' <- `w'?`}*{`w'?` <- `w'?*`}) = lift(w?{w <- `w?`}) ++ $concat_(syntax X, lift(w'?{w' <- `w'?`})*{`w'?` <- `w'?*`}) - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -def $inv_concat_(syntax X, X*) : X** - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -def $inv_concatn_(syntax X, nat : nat, X*) : X** - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:35.1-35.78 -def $disjoint_(syntax X, X*) : bool - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:36.1-36.37 - def $disjoint_{syntax X}(syntax X, []) = true - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:37.1-37.68 - def $disjoint_{syntax X, w : X, `w'*` : X*}(syntax X, [w] ++ w'*{w' <- `w'*`}) = (~ (w <- w'*{w' <- `w'*`}) /\ $disjoint_(syntax X, w'*{w' <- `w'*`})) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:40.1-40.38 -def $setminus1_(syntax X, X : X, X*) : X* - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:44.1-44.38 - def $setminus1_{syntax X, w : X}(syntax X, w, []) = [w] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:45.1-45.78 - def $setminus1_{syntax X, w : X, w_1 : X, `w'*` : X*}(syntax X, w, [w_1] ++ w'*{w' <- `w'*`}) = (if (w = w_1) then [] else $setminus1_(syntax X, w, w'*{w' <- `w'*`})) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:39.1-39.56 -def $setminus_(syntax X, X*, X*) : X* - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:42.1-42.40 - def $setminus_{syntax X, `w*` : X*}(syntax X, [], w*{w <- `w*`}) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:43.1-43.90 - def $setminus_{syntax X, w_1 : X, `w'*` : X*, `w*` : X*}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}) = $setminus1_(syntax X, w_1, w*{w <- `w*`}) ++ $setminus_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:51.1-51.46 -def $setproduct2_(syntax X, X : X, X**) : X** - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:57.1-57.44 - def $setproduct2_{syntax X, w_1 : X}(syntax X, w_1, []) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:58.1-58.90 - def $setproduct2_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, w_1, [w'*{w' <- `w'*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = [[w_1] ++ w'*{w' <- `w'*`}] ++ $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:50.1-50.47 -def $setproduct1_(syntax X, X*, X**) : X** - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:55.1-55.46 - def $setproduct1_{syntax X, `w**` : X**}(syntax X, [], w*{w <- `w*`}*{`w*` <- `w**`}) = [] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:56.1-56.107 - def $setproduct1_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) ++ $setproduct1_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) -} - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec -rec { - -;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:49.1-49.84 -def $setproduct_(syntax X, X**) : X** - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:53.1-53.40 - def $setproduct_{syntax X}(syntax X, []) = [[]] - ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:54.1-54.90 - def $setproduct_{syntax X, `w_1*` : X*, `w**` : X**}(syntax X, [w_1*{w_1 <- `w_1*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct1_(syntax X, w_1*{w_1 <- `w_1*`}, $setproduct_(syntax X, w*{w <- `w*`}*{`w*` <- `w**`})) -} - -;; ../../../../specification/wasm-3.0/1.0-syntax.profiles.spectec -def $ND : bool - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax bit = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_bit: `%`(bit) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule bit_case_0{i : nat}: - `%`(`%`_bit(i)) - -- if ((i = 0) \/ (i = 1)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax byte = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_byte: `%`(byte) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule byte_case_0{i : nat}: - `%`(`%`_byte(i)) - -- if ((i >= 0) /\ (i <= 255)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax uN = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_uN: `%%`(N, uN) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule uN_case_0{N : N, i : nat}: - `%%`(N, `%`_uN(i)) - -- if ((i >= 0) /\ (i <= ((((2 ^ N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax sN = - | `%`(i : int) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_sN: `%%`(N, sN) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule sN_case_0{N : N, i : int}: - `%%`(N, `%`_sN(i)) - -- if ((((i >= - ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) /\ (i <= - (1 : nat <:> int))) \/ (i = (0 : nat <:> int))) \/ ((i >= + (1 : nat <:> int)) /\ (i <= (+ ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax iN = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax u8 = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax u16 = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax u31 = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax u32 = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax u64 = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax s33 = sN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax i32 = iN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax i64 = iN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax i128 = iN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $signif(N : N) : nat? - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(32) = ?(23) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(64) = ?(52) - def $signif{x0 : N}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $expon(N : N) : nat? - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(32) = ?(8) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(64) = ?(11) - def $expon{x0 : N}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $M(N : N) : nat - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $M{N : nat}(N) = !($signif(N)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $E(N : N) : nat - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $E{N : nat}(N) = !($expon(N)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax exp = int - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax fNmag = - | NORM(m : m, exp : exp) - | SUBNORM(m : m) - | INF - | NAN(m : m) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_fNmag: `%%`(N, fNmag) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_0{N : N, m : m, exp : exp}: - `%%`(N, NORM_fNmag(m, exp)) - -- if ((m < (2 ^ $M(N))) /\ ((((2 : nat <:> int) - ((2 ^ ((($E(N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ ((($E(N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_1{N : N, exp : exp, m : m}: - `%%`(N, SUBNORM_fNmag(m)) - -- if ((m < (2 ^ $M(N))) /\ (((2 : nat <:> int) - ((2 ^ ((($E(N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_2{N : N}: - `%%`(N, INF_fNmag) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_3{N : N, m : m}: - `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax fN = - | POS(fNmag) - | NEG(fNmag) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_fN: `%%`(N, fN) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fN_case_0{N : N, var_0 : fNmag}: - `%%`(N, POS_fN(var_0)) - -- wf_fNmag: `%%`(N, var_0) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fN_case_1{N : N, var_0 : fNmag}: - `%%`(N, NEG_fN(var_0)) - -- wf_fNmag: `%%`(N, var_0) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax f32 = fN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax f64 = fN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fzero(N : N) : fN - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fnat(N : N, nat : nat) : fN - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fone(N : N) : fN - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $canon_(N : N) : nat - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $canon_{N : nat}(N) = (2 ^ (((!($signif(N)) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax vN = uN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax v128 = vN - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax list{syntax X}(syntax X) = - | `%`(`X*` : X*) - -- if (|X*{X <- `X*`}| < (2 ^ 32)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax char = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_char: `%`(char) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule char_case_0{i : nat}: - `%`(`%`_char(i)) - -- if (((i >= 0) /\ (i <= 55295)) \/ ((i >= 57344) /\ (i <= 1114111))) - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -def $cont(byte : byte) : nat - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - def $cont{b : byte}(b) = (((b!`%`_byte.0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat) - -- if ((128 < b!`%`_byte.0) /\ (b!`%`_byte.0 < 192)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.1-91.25 -def $utf8(char*) : byte* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:52.1-52.44 - def $utf8{`ch*` : char*}(ch*{ch <- `ch*`}) = $concat_(syntax byte, $utf8([ch])*{ch <- `ch*`}) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:53.1-55.15 - def $utf8{ch : char}([ch]) = [b] - -- if (ch!`%`_char.0 < 128) - -- let{b : byte} b = `%`_byte(ch!`%`_char.0) - -- wf_byte: `%`(`%`_byte(ch!`%`_char.0)) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:56.1-58.46 - def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] - -- if ((128 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 2048)) - -- if (ch!`%`_char.0 = (((2 ^ 6) * (((b_1!`%`_byte.0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] - -- if (((2048 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 55296)) \/ ((57344 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 65536))) - -- if (ch!`%`_char.0 = ((((2 ^ 12) * (((b_1!`%`_byte.0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] - -- if ((65536 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 69632)) - -- if (ch!`%`_char.0 = (((((2 ^ 18) * (((b_1!`%`_byte.0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax name = - | `%`(`char*` : char*) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_name: `%`(name) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule name_case_0{`char*` : char*}: - `%`(`%`_name(`char*`)) - -- (wf_char: `%`(char))*{char <- `char*`} - -- if (|$utf8(char*{char <- `char*`})| < (2 ^ 32)) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax idx = u32 - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax laneidx = u8 - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax typeidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax funcidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax globalidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax tableidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax memidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax tagidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax elemidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax dataidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax labelidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax localidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax fieldidx = idx - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax externidx = - | FUNC(funcidx : funcidx) - | GLOBAL(globalidx : globalidx) - | TABLE(tableidx : tableidx) - | MEM(memidx : memidx) - | TAG(tagidx : tagidx) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_externidx: `%`(externidx) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule externidx_case_0{funcidx : funcidx}: - `%`(FUNC_externidx(funcidx)) - -- wf_uN: `%%`(32, funcidx) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule externidx_case_1{globalidx : globalidx}: - `%`(GLOBAL_externidx(globalidx)) - -- wf_uN: `%%`(32, globalidx) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule externidx_case_2{tableidx : tableidx}: - `%`(TABLE_externidx(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule externidx_case_3{memidx : memidx}: - `%`(MEM_externidx(memidx)) - -- wf_uN: `%%`(32, memidx) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule externidx_case_4{tagidx : tagidx}: - `%`(TAG_externidx(tagidx)) - -- wf_uN: `%%`(32, tagidx) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.1-129.86 -def $funcsxx(externidx*) : typeidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:135.1-135.24 - def $funcsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:136.1-136.45 - def $funcsxx{x : uN, `xx*` : externidx*}([FUNC_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $funcsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:137.1-137.58 - def $funcsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $funcsxx(xx*{xx <- `xx*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.1-130.88 -def $globalsxx(externidx*) : globalidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:139.1-139.26 - def $globalsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:140.1-140.51 - def $globalsxx{x : uN, `xx*` : externidx*}([GLOBAL_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $globalsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:141.1-141.62 - def $globalsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $globalsxx(xx*{xx <- `xx*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.1-131.87 -def $tablesxx(externidx*) : tableidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:143.1-143.25 - def $tablesxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:144.1-144.48 - def $tablesxx{x : uN, `xx*` : externidx*}([TABLE_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tablesxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:145.1-145.60 - def $tablesxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tablesxx(xx*{xx <- `xx*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.1-132.85 -def $memsxx(externidx*) : memidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:147.1-147.23 - def $memsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:148.1-148.42 - def $memsxx{x : uN, `xx*` : externidx*}([MEM_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $memsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:149.1-149.56 - def $memsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $memsxx(xx*{xx <- `xx*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.1-133.85 -def $tagsxx(externidx*) : tagidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:151.1-151.23 - def $tagsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:152.1-152.42 - def $tagsxx{x : uN, `xx*` : externidx*}([TAG_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tagsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:153.1-153.56 - def $tagsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tagsxx(xx*{xx <- `xx*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -syntax free = -{ - TYPES typeidx*, - FUNCS funcidx*, - GLOBALS globalidx*, - TABLES tableidx*, - MEMS memidx*, - ELEMS elemidx*, - DATAS dataidx*, - LOCALS localidx*, - LABELS labelidx*, - TAGS tagidx* -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation wf_free: `%`(free) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule free_case_{var_0 : typeidx*, var_1 : funcidx*, var_2 : globalidx*, var_3 : tableidx*, var_4 : memidx*, var_5 : elemidx*, var_6 : dataidx*, var_7 : localidx*, var_8 : labelidx*, var_9 : tagidx*}: - `%`({TYPES var_0, FUNCS var_1, GLOBALS var_2, TABLES var_3, MEMS var_4, ELEMS var_5, DATAS var_6, LOCALS var_7, LABELS var_8, TAGS var_9}) - -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} - -- (wf_uN: `%%`(32, var_1))*{var_1 <- var_1} - -- (wf_uN: `%%`(32, var_2))*{var_2 <- var_2} - -- (wf_uN: `%%`(32, var_3))*{var_3 <- var_3} - -- (wf_uN: `%%`(32, var_4))*{var_4 <- var_4} - -- (wf_uN: `%%`(32, var_5))*{var_5 <- var_5} - -- (wf_uN: `%%`(32, var_6))*{var_6 <- var_6} - -- (wf_uN: `%%`(32, var_7))*{var_7 <- var_7} - -- (wf_uN: `%%`(32, var_8))*{var_8 <- var_8} - -- (wf_uN: `%%`(32, var_9))*{var_9 <- var_9} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_opt(free?) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_opt{free : free}(?(free)) = free - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.1-173.29 -def $free_list(free*) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 - def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 - def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) -} - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_typeidx(typeidx : typeidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_funcidx(funcidx : funcidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_globalidx(globalidx : globalidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_tableidx(tableidx : tableidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_memidx(memidx : memidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_elemidx(elemidx : elemidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_dataidx(dataidx : dataidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_localidx(localidx : localidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_labelidx(labelidx : labelidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_tagidx(tagidx : tagidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_externidx(externidx : externidx) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{funcidx : uN}(FUNC_externidx(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{globalidx : uN}(GLOBAL_externidx(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tableidx : uN}(TABLE_externidx(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{memidx : uN}(MEM_externidx(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax null = - | NULL - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax addrtype = - | I32 - | I64 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax numtype = - | I32 - | I64 - | F32 - | F64 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax vectype = - | V128 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax consttype = - | I32 - | I64 - | F32 - | F64 - | V128 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax absheaptype = - | ANY - | EQ - | I31 - | STRUCT - | ARRAY - | NONE - | FUNC - | NOFUNC - | EXN - | NOEXN - | EXTERN - | NOEXTERN - | BOT - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax mut = - | MUT - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax final = - | FINAL - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:37.1-38.43 -syntax typeuse = - | _IDX(typeidx : typeidx) - | _DEF(rectype : rectype, n : n) - | REC(n : n) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.1-44.26 -syntax heaptype = - | ANY - | EQ - | I31 - | STRUCT - | ARRAY - | NONE - | FUNC - | NOFUNC - | EXN - | NOEXN - | EXTERN - | NOEXTERN - | BOT - | _IDX(typeidx : typeidx) - | _DEF(rectype : rectype, n : n) - | REC(n : n) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.1-52.14 -syntax valtype = - | I32 - | I64 - | F32 - | F64 - | V128 - | REF(`null?` : null?, heaptype : heaptype) - | BOT - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.1-92.66 -syntax storagetype = - | I32 - | I64 - | F32 - | F64 - | V128 - | REF(`null?` : null?, heaptype : heaptype) - | BOT - | I8 - | I16 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:102.1-103.16 -syntax resulttype = list(syntax valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.1-112.61 -syntax fieldtype = - | `%%`(`mut?` : mut?, storagetype : storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.1-117.34 -syntax comptype = - | STRUCT(list(syntax fieldtype)) - | ARRAY(fieldtype : fieldtype) - | `FUNC%->%`(resulttype : resulttype, resulttype : resulttype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:119.1-120.33 -syntax subtype = - | SUB(`final?` : final?, `typeuse*` : typeuse*, comptype : comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:122.1-123.22 -syntax rectype = - | REC(list(syntax subtype)) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:37.8-37.15 -relation wf_typeuse: `%`(typeuse) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:37.8-37.15 - rule typeuse_case_0{typeidx : typeidx}: - `%`(_IDX_typeuse(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:37.8-37.15 - rule typeuse_case_1{rectype : rectype, n : n}: - `%`(_DEF_typeuse(rectype, n)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:37.8-37.15 - rule typeuse_case_2{n : n}: - `%`(REC_typeuse(n)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 -relation wf_heaptype: `%`(heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_0: - `%`(ANY_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_1: - `%`(EQ_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_2: - `%`(I31_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_3: - `%`(STRUCT_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_4: - `%`(ARRAY_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_5: - `%`(NONE_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_6: - `%`(FUNC_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_7: - `%`(NOFUNC_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_8: - `%`(EXN_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_9: - `%`(NOEXN_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_10: - `%`(EXTERN_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_11: - `%`(NOEXTERN_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_12: - `%`(BOT_heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_13{typeidx : typeidx}: - `%`(_IDX_heaptype(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_14{rectype : rectype, n : n}: - `%`(_DEF_heaptype(rectype, n)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:43.8-43.16 - rule heaptype_case_15{n : n}: - `%`(REC_heaptype(n)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 -relation wf_valtype: `%`(valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_0: - `%`(I32_valtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_1: - `%`(I64_valtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_2: - `%`(F32_valtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_3: - `%`(F64_valtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_4: - `%`(V128_valtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_5{`null?` : null?, heaptype : heaptype}: - `%`(REF_valtype(`null?`, heaptype)) - -- wf_heaptype: `%`(heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:51.8-51.15 - rule valtype_case_6: - `%`(BOT_valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 -relation wf_storagetype: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_0: - `%`(I32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_5{`null?` : null?, heaptype : heaptype}: - `%`(REF_storagetype(`null?`, heaptype)) - -- wf_heaptype: `%`(heaptype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_6: - `%`(BOT_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_7: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:92.8-92.19 - rule storagetype_case_8: - `%`(I16_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.8-112.17 -relation wf_fieldtype: `%`(fieldtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.8-112.17 - rule fieldtype_case_0{`mut?` : mut?, storagetype : storagetype}: - `%`(`%%`_fieldtype(`mut?`, storagetype)) - -- wf_storagetype: `%`(storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.8-114.16 -relation wf_comptype: `%`(comptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.8-114.16 - rule comptype_case_0{var_0 : list(syntax fieldtype)}: - `%`(STRUCT_comptype(var_0)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.8-114.16 - rule comptype_case_1{fieldtype : fieldtype}: - `%`(ARRAY_comptype(fieldtype)) - -- wf_fieldtype: `%`(fieldtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.8-114.16 - rule comptype_case_2{resulttype : resulttype, resulttype_0 : resulttype}: - `%`(`FUNC%->%`_comptype(resulttype, resulttype_0)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:119.8-119.15 -relation wf_subtype: `%`(subtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:119.8-119.15 - rule subtype_case_0{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype}: - `%`(SUB_subtype(`final?`, `typeuse*`, comptype)) - -- (wf_typeuse: `%`(typeuse))*{typeuse <- `typeuse*`} - -- wf_comptype: `%`(comptype) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax deftype = - | _DEF(rectype : rectype, n : n) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax typevar = - | _IDX(typeidx : typeidx) - | REC(n : n) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_typevar: `%`(typevar) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule typevar_case_0{typeidx : typeidx}: - `%`(_IDX_typevar(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule typevar_case_1{n : n}: - `%`(REC_typevar(n)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax reftype = - | REF(`null?` : null?, heaptype : heaptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_reftype: `%`(reftype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule reftype_case_0{`null?` : null?, heaptype : heaptype}: - `%`(REF_reftype(`null?`, heaptype)) - -- wf_heaptype: `%`(heaptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Inn = addrtype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Fnn = - | F32 - | F64 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Vnn = vectype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Cnn = - | I32 - | I64 - | F32 - | F64 - | V128 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $ANYREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $EQREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $I31REF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $STRUCTREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $ARRAYREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $FUNCREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $EXNREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $EXTERNREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $NULLREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $NULLFUNCREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $NULLEXNREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $NULLEXTERNREF : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax packtype = - | I8 - | I16 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax lanetype = - | I32 - | I64 - | F32 - | F64 - | I8 - | I16 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Pnn = packtype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Jnn = - | I32 - | I64 - | I8 - | I16 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax Lnn = lanetype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax limits = - | `[%..%]`(u64 : u64, `u64?` : u64?) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_limits: `%`(limits) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule limits_case_0{u64 : u64, `u64?` : u64?}: - `%`(`[%..%]`_limits(u64, `u64?`)) - -- wf_uN: `%%`(64, u64) - -- (wf_uN: `%%`(64, u64))?{u64 <- `u64?`} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax tagtype = typeuse - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax globaltype = - | `%%`(`mut?` : mut?, valtype : valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_globaltype: `%`(globaltype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule globaltype_case_0{`mut?` : mut?, valtype : valtype}: - `%`(`%%`_globaltype(`mut?`, valtype)) - -- wf_valtype: `%`(valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax memtype = - | `%%PAGE`(addrtype : addrtype, limits : limits) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_memtype: `%`(memtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule memtype_case_0{addrtype : addrtype, limits : limits}: - `%`(`%%PAGE`_memtype(addrtype, limits)) - -- wf_limits: `%`(limits) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax tabletype = - | `%%%`(addrtype : addrtype, limits : limits, reftype : reftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_tabletype: `%`(tabletype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule tabletype_case_0{addrtype : addrtype, limits : limits, reftype : reftype}: - `%`(`%%%`_tabletype(addrtype, limits, reftype)) - -- wf_limits: `%`(limits) - -- wf_reftype: `%`(reftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax datatype = - | OK - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax elemtype = reftype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax externtype = - | TAG(tagtype : tagtype) - | GLOBAL(globaltype : globaltype) - | MEM(memtype : memtype) - | TABLE(tabletype : tabletype) - | FUNC(typeuse : typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_externtype: `%`(externtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule externtype_case_0{tagtype : tagtype}: - `%`(TAG_externtype(tagtype)) - -- wf_typeuse: `%`(tagtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule externtype_case_1{globaltype : globaltype}: - `%`(GLOBAL_externtype(globaltype)) - -- wf_globaltype: `%`(globaltype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule externtype_case_2{memtype : memtype}: - `%`(MEM_externtype(memtype)) - -- wf_memtype: `%`(memtype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule externtype_case_3{tabletype : tabletype}: - `%`(TABLE_externtype(tabletype)) - -- wf_tabletype: `%`(tabletype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule externtype_case_4{typeuse : typeuse}: - `%`(FUNC_externtype(typeuse)) - -- wf_typeuse: `%`(typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax moduletype = - | `%->%`(`externtype*` : externtype*, `externtype*` : externtype*) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation wf_moduletype: `%`(moduletype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule moduletype_case_0{`externtype*` : externtype*, `externtype*_0` : externtype*}: - `%`(`%->%`_moduletype(`externtype*`, `externtype*_0`)) - -- (wf_externtype: `%`(externtype))*{externtype <- `externtype*`} - -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $IN(N : N) : Inn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(32) = ?(I32_Inn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(64) = ?(I64_Inn) - def $IN{x0 : N}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $FN(N : N) : Fnn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(32) = ?(F32_Fnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(64) = ?(F64_Fnn) - def $FN{x0 : N}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $JN(N : N) : Jnn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(8) = ?(I8_Jnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(16) = ?(I16_Jnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(32) = ?(I32_Jnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(64) = ?(I64_Jnn) - def $JN{x0 : N}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $size(numtype : numtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $size(I32_numtype) = 32 - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $size(I64_numtype) = 64 - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $size(F32_numtype) = 32 - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $size(F64_numtype) = 64 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vsize(vectype : vectype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vsize(V128_vectype) = 128 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $psize(packtype : packtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $psize(I8_packtype) = 8 - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $psize(I16_packtype) = 16 - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $lsize(lanetype : lanetype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{numtype : numtype}((numtype : numtype <: lanetype)) = $size(numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{packtype : packtype}((packtype : packtype <: lanetype)) = $psize(packtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $zsize(storagetype : storagetype) : nat? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{numtype : numtype}((numtype : numtype <: storagetype)) = ?($size(numtype)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{vectype : vectype}((vectype : vectype <: storagetype)) = ?($vsize(vectype)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{packtype : packtype}((packtype : packtype <: storagetype)) = ?($psize(packtype)) - def $zsize{x0 : storagetype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $isize(Inn : Inn) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $isize{Inn : addrtype}(Inn) = $size((Inn : addrtype <: numtype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $jsize(Jnn : Jnn) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsize{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $fsize(Fnn : Fnn) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $fsize{Fnn : Fnn}(Fnn) = $size((Fnn : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_isize(nat : nat) : Inn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(32) = ?(I32_Inn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(64) = ?(I64_Inn) - def $inv_isize{x0 : nat}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsize(nat : nat) : Jnn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(8) = ?(I8_Jnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(16) = ?(I16_Jnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize{n : nat}(n) = (iter_val#1 : addrtype <: Jnn)?{iter_val#1 <- $inv_isize(n)} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_fsize(nat : nat) : Fnn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(32) = ?(F32_Fnn) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(64) = ?(F64_Fnn) - def $inv_fsize{x0 : nat}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $sizenn(numtype : numtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $sizenn{nt : numtype}(nt) = $size(nt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $sizenn1(numtype : numtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $sizenn1{nt : numtype}(nt) = $size(nt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $sizenn2(numtype : numtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $sizenn2{nt : numtype}(nt) = $size(nt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vsizenn(vectype : vectype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vsizenn{vt : vectype}(vt) = $vsize(vt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $psizenn(packtype : packtype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $psizenn{pt : packtype}(pt) = $psize(pt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $lsizenn(lanetype : lanetype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsizenn{lt : lanetype}(lt) = $lsize(lt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $lsizenn1(lanetype : lanetype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsizenn1{lt : lanetype}(lt) = $lsize(lt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $lsizenn2(lanetype : lanetype) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsizenn2{lt : lanetype}(lt) = $lsize(lt) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $jsizenn(Jnn : Jnn) : nat - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsizenn{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsizenn(nat : nat) : Jnn? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $lunpack(lanetype : lanetype) : numtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{numtype : numtype}((numtype : numtype <: lanetype)) = numtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{packtype : packtype}((packtype : packtype <: lanetype)) = I32_numtype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $unpack(storagetype : storagetype) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $nunpack(storagetype : storagetype) : numtype? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{numtype : numtype}((numtype : numtype <: storagetype)) = ?(numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_numtype) - def $nunpack{x0 : storagetype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vunpack(storagetype : storagetype) : vectype? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack{vectype : vectype}((vectype : vectype <: storagetype)) = ?(vectype) - def $vunpack{x0 : storagetype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $cunpack(storagetype : storagetype) : consttype? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{consttype : consttype}((consttype : consttype <: storagetype)) = ?(consttype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_consttype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{lanetype : lanetype}((lanetype : lanetype <: storagetype)) = ?(($lunpack(lanetype) : numtype <: consttype)) - def $cunpack{x0 : storagetype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $minat{at_1 : addrtype, at_2 : addrtype}(at_1, at_2) = (if ($size((at_1 : addrtype <: numtype)) <= $size((at_2 : addrtype <: numtype))) then at_1 else at_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $diffrt(reftype : reftype, reftype : reftype) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $as_deftype(typeuse : typeuse) : deftype? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $as_deftype{dt : deftype}((dt : deftype <: typeuse)) = ?(dt) - def $as_deftype{x0 : typeuse}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.1-308.87 -def $tagsxt(externtype*) : tagtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:314.1-314.23 - def $tagsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:315.1-315.44 - def $tagsxt{jt : typeuse, `xt*` : externtype*}([TAG_externtype(jt)] ++ xt*{xt <- `xt*`}) = [jt] ++ $tagsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:316.1-316.57 - def $tagsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tagsxt(xt*{xt <- `xt*`}) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.1-309.90 -def $globalsxt(externtype*) : globaltype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:318.1-318.26 - def $globalsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:319.1-319.53 - def $globalsxt{gt : globaltype, `xt*` : externtype*}([GLOBAL_externtype(gt)] ++ xt*{xt <- `xt*`}) = [gt] ++ $globalsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:320.1-320.63 - def $globalsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $globalsxt(xt*{xt <- `xt*`}) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 -def $memsxt(externtype*) : memtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 - def $memsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:323.1-323.44 - def $memsxt{mt : memtype, `xt*` : externtype*}([MEM_externtype(mt)] ++ xt*{xt <- `xt*`}) = [mt] ++ $memsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:324.1-324.57 - def $memsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $memsxt(xt*{xt <- `xt*`}) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 -def $tablesxt(externtype*) : tabletype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 - def $tablesxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:327.1-327.50 - def $tablesxt{tt : tabletype, `xt*` : externtype*}([TABLE_externtype(tt)] ++ xt*{xt <- `xt*`}) = [tt] ++ $tablesxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:328.1-328.61 - def $tablesxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tablesxt(xt*{xt <- `xt*`}) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 -def $funcsxt(externtype*) : deftype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 - def $funcsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:331.1-331.47 - def $funcsxt{dt : deftype, `xt*` : externtype*}([FUNC_externtype((dt : deftype <: typeuse))] ++ xt*{xt <- `xt*`}) = [dt] ++ $funcsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:332.1-332.59 - def $funcsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $funcsxt(xt*{xt <- `xt*`}) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.1-337.126 -def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:365.1-365.38 - def $subst_typevar{tv : typevar}(tv, [], []) = ?((tv : typevar <: typeuse)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:366.1-366.95 - def $subst_typevar{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*}(tv, [tv_1] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`}) = (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- $subst_typevar(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})} - def $subst_typevar{x0 : typevar, x1 : typevar*, x2 : typeuse*}(x0, x1, x2) = ?() - -- otherwise -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 -def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 - def $minus_recs([], []) = ?(([], [])) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:403.1-403.63 - def $minus_recs{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([REC_typevar(n)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 - def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) - def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() - -- otherwise -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_packtype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = pt - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_numtype(numtype : numtype, typevar*, typeuse*) : numtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_numtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = nt - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_vectype(vectype : vectype, typevar*, typeuse*) : vectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_vectype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = vt - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.1-338.112 -def $subst_typeuse(typeuse : typeuse, typevar*, typeuse*) : typeuse - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = !($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:370.1-370.64 - def $subst_typeuse{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.1-343.112 -def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = (!($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) : typeuse <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:377.1-377.65 - def $subst_heaptype{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:378.1-378.53 - def $subst_heaptype{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ht - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.1-344.112 -def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 - def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 -def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}((nt : numtype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_numtype(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : numtype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}((vt : vectype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_vectype(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : vectype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 -def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{t : valtype, `tv*` : typevar*, `tu*` : typeuse*}((t : valtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : valtype <: storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}((pt : packtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_packtype(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : packtype <: storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 -def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 -def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 -def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 -def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st*{st <- `st*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 -def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = at - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(valtype : valtype, typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_comptype(resulttype_1, resulttype_2)) = $free_resulttype(resulttype_1) +++ $free_resulttype(resulttype_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.1-491.34 -def $free_subtype(subtype : subtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:550.1-551.66 - def $free_subtype{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype}(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) = $free_list($free_typeuse(typeuse)*{typeuse <- `typeuse*`}) +++ $free_comptype(comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.1-492.34 -def $free_rectype(rectype : rectype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:553.1-553.70 - def $free_rectype{`subtype*` : subtype*}(REC_rectype(`%`_list(subtype*{subtype <- `subtype*`}))) = $free_list($free_subtype(subtype)*{subtype <- `subtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.1-520.34 -def $free_deftype(deftype : deftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:521.1-521.59 - def $free_deftype{rectype : rectype, n : nat}(_DEF_deftype(rectype, n)) = $free_rectype(rectype) -} - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tagtype(tagtype : tagtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{deftype : deftype}((deftype : deftype <: typeuse)) = $free_deftype(deftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_globaltype(globaltype : globaltype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_globaltype{`mut?` : mut?, valtype : valtype}(`%%`_globaltype(mut?{mut <- `mut?`}, valtype)) = $free_valtype(valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_memtype(memtype : memtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_memtype{addrtype : addrtype, limits : limits}(`%%PAGE`_memtype(addrtype, limits)) = $free_addrtype(addrtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tabletype{addrtype : addrtype, limits : limits, reftype : reftype}(`%%%`_tabletype(addrtype, limits, reftype)) = $free_addrtype(addrtype) +++ $free_reftype(reftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_datatype(datatype : datatype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_datatype(OK_datatype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_elemtype(elemtype : elemtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_externtype(externtype : externtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tagtype : typeuse}(TAG_externtype(tagtype)) = $free_tagtype(tagtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_moduletype(moduletype : moduletype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_moduletype{`externtype_1*` : externtype*, `externtype_2*` : externtype*}(`%->%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax num_ = - | mk_num__0(Inn : Inn, var_x : iN) - | mk_num__1(Fnn : Fnn, var_x : fN) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_num_: `%%`(numtype, num_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule num__case_0{numtype : numtype, Inn : Inn, var_x : iN}: - `%%`(numtype, mk_num__0_num_(Inn, var_x)) - -- wf_uN: `%%`($size((Inn : addrtype <: numtype)), var_x) - -- if (numtype = (Inn : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule num__case_1{numtype : numtype, Fnn : Fnn, var_x : fN}: - `%%`(numtype, mk_num__1_num_(Fnn, var_x)) - -- wf_fN: `%%`($sizenn((Fnn : Fnn <: numtype)), var_x) - -- if (numtype = (Fnn : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_num__0(var_x : num_) : iN? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_num__0{Inn : Inn, var_x : iN}(mk_num__0_num_(Inn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_num__0{var_x : num_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_num__1(var_x : num_) : fN? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_num__1{Fnn : Fnn, var_x : fN}(mk_num__1_num_(Fnn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_num__1{var_x : num_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax pack_ = iN - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax lane_ = - | mk_lane__0(numtype : numtype, var_x : num_) - | mk_lane__1(packtype : packtype, var_x : pack_) - | mk_lane__2(Jnn : Jnn, var_x : iN) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_lane_: `%%`(lanetype, lane_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lane__case_0{lanetype : lanetype, numtype : numtype, var_x : num_}: - `%%`(lanetype, mk_lane__0_lane_(numtype, var_x)) - -- wf_num_: `%%`(numtype, var_x) - -- if (lanetype = (numtype : numtype <: lanetype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lane__case_1{lanetype : lanetype, packtype : packtype, var_x : pack_}: - `%%`(lanetype, mk_lane__1_lane_(packtype, var_x)) - -- wf_uN: `%%`($psize(packtype), var_x) - -- if (lanetype = (packtype : packtype <: lanetype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lane__case_2{lanetype : lanetype, Jnn : Jnn, var_x : iN}: - `%%`(lanetype, mk_lane__2_lane_(Jnn, var_x)) - -- wf_uN: `%%`($lsize((Jnn : Jnn <: lanetype)), var_x) - -- if (lanetype = (Jnn : Jnn <: lanetype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lane__0(var_x : lane_) : num_? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__0{numtype : numtype, var_x : num_}(mk_lane__0_lane_(numtype, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__0{var_x : lane_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lane__1(var_x : lane_) : pack_? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__1{packtype : packtype, var_x : pack_}(mk_lane__1_lane_(packtype, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__1{var_x : lane_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lane__2(var_x : lane_) : iN? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__2{Jnn : Jnn, var_x : iN}(mk_lane__2_lane_(Jnn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lane__2{var_x : lane_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vec_ = vN - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax lit_ = - | mk_lit__0(numtype : numtype, var_x : num_) - | mk_lit__1(vectype : vectype, var_x : vec_) - | mk_lit__2(packtype : packtype, var_x : pack_) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_lit_: `%%`(storagetype, lit_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lit__case_0{storagetype : storagetype, numtype : numtype, var_x : num_}: - `%%`(storagetype, mk_lit__0_lit_(numtype, var_x)) - -- wf_num_: `%%`(numtype, var_x) - -- if (storagetype = (numtype : numtype <: storagetype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lit__case_1{storagetype : storagetype, vectype : vectype, var_x : vec_}: - `%%`(storagetype, mk_lit__1_lit_(vectype, var_x)) - -- wf_uN: `%%`($vsize(vectype), var_x) - -- if (storagetype = (vectype : vectype <: storagetype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule lit__case_2{storagetype : storagetype, packtype : packtype, var_x : pack_}: - `%%`(storagetype, mk_lit__2_lit_(packtype, var_x)) - -- wf_uN: `%%`($psize(packtype), var_x) - -- if (storagetype = (packtype : packtype <: storagetype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lit__0(var_x : lit_) : num_? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__0{numtype : numtype, var_x : num_}(mk_lit__0_lit_(numtype, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__0{var_x : lit_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lit__1(var_x : lit_) : vec_? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__1{vectype : vectype, var_x : vec_}(mk_lit__1_lit_(vectype, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__1{var_x : lit_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_lit__2(var_x : lit_) : pack_? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__2{packtype : packtype, var_x : pack_}(mk_lit__2_lit_(packtype, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_lit__2{var_x : lit_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax sz = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_sz: `%`(sz) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule sz_case_0{i : nat}: - `%`(`%`_sz(i)) - -- if ((((i = 8) \/ (i = 16)) \/ (i = 32)) \/ (i = 64)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax sx = - | U - | S - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax unop_Inn = - | CLZ - | CTZ - | POPCNT - | EXTEND(sz : sz) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_unop_Inn: `%%`(Inn, unop_Inn) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop_Inn_case_0{Inn : Inn}: - `%%`(Inn, CLZ_unop_Inn) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop_Inn_case_1{Inn : Inn}: - `%%`(Inn, CTZ_unop_Inn) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop_Inn_case_2{Inn : Inn}: - `%%`(Inn, POPCNT_unop_Inn) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop_Inn_case_3{Inn : Inn, sz : sz}: - `%%`(Inn, EXTEND_unop_Inn(sz)) - -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax unop_Fnn = - | ABS - | NEG - | SQRT - | CEIL - | FLOOR - | TRUNC - | NEAREST - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax unop_ = - | mk_unop__0(Inn : Inn, var_x : unop_Inn) - | mk_unop__1(Fnn : Fnn, var_x : unop_Fnn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_unop_: `%%`(numtype, unop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop__case_0{numtype : numtype, Inn : Inn, var_x : unop_Inn}: - `%%`(numtype, mk_unop__0_unop_(Inn, var_x)) - -- wf_unop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule unop__case_1{numtype : numtype, Fnn : Fnn, var_x : unop_Fnn}: - `%%`(numtype, mk_unop__1_unop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_unop__0(var_x : unop_) : unop_Inn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_unop__0{Inn : Inn, var_x : unop_Inn}(mk_unop__0_unop_(Inn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_unop__0{var_x : unop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_unop__1(var_x : unop_) : unop_Fnn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_unop__1{Fnn : Fnn, var_x : unop_Fnn}(mk_unop__1_unop_(Fnn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_unop__1{var_x : unop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax binop_Inn = - | ADD - | SUB - | MUL - | DIV(sx : sx) - | REM(sx : sx) - | AND - | OR - | XOR - | SHL - | SHR(sx : sx) - | ROTL - | ROTR - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax binop_Fnn = - | ADD - | SUB - | MUL - | DIV - | MIN - | MAX - | COPYSIGN - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax binop_ = - | mk_binop__0(Inn : Inn, var_x : binop_Inn) - | mk_binop__1(Fnn : Fnn, var_x : binop_Fnn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_binop_: `%%`(numtype, binop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule binop__case_0{numtype : numtype, Inn : Inn, var_x : binop_Inn}: - `%%`(numtype, mk_binop__0_binop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule binop__case_1{numtype : numtype, Fnn : Fnn, var_x : binop_Fnn}: - `%%`(numtype, mk_binop__1_binop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_binop__0(var_x : binop_) : binop_Inn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_binop__0{Inn : Inn, var_x : binop_Inn}(mk_binop__0_binop_(Inn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_binop__0{var_x : binop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_binop__1(var_x : binop_) : binop_Fnn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_binop__1{Fnn : Fnn, var_x : binop_Fnn}(mk_binop__1_binop_(Fnn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_binop__1{var_x : binop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax testop_Inn = - | EQZ - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax testop_ = - | mk_testop__0(Inn : Inn, var_x : testop_Inn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_testop_: `%%`(numtype, testop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule testop__case_0{numtype : numtype, Inn : Inn, var_x : testop_Inn}: - `%%`(numtype, mk_testop__0_testop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_testop__0(var_x : testop_) : testop_Inn - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_testop__0{Inn : Inn, var_x : testop_Inn}(mk_testop__0_testop_(Inn, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax relop_Inn = - | EQ - | NE - | LT(sx : sx) - | GT(sx : sx) - | LE(sx : sx) - | GE(sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax relop_Fnn = - | EQ - | NE - | LT - | GT - | LE - | GE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax relop_ = - | mk_relop__0(Inn : Inn, var_x : relop_Inn) - | mk_relop__1(Fnn : Fnn, var_x : relop_Fnn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_relop_: `%%`(numtype, relop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule relop__case_0{numtype : numtype, Inn : Inn, var_x : relop_Inn}: - `%%`(numtype, mk_relop__0_relop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule relop__case_1{numtype : numtype, Fnn : Fnn, var_x : relop_Fnn}: - `%%`(numtype, mk_relop__1_relop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_relop__0(var_x : relop_) : relop_Inn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_relop__0{Inn : Inn, var_x : relop_Inn}(mk_relop__0_relop_(Inn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_relop__0{var_x : relop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_relop__1(var_x : relop_) : relop_Fnn? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_relop__1{Fnn : Fnn, var_x : relop_Fnn}(mk_relop__1_relop_(Fnn, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_relop__1{var_x : relop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax cvtop__Inn_1_Inn_2 = - | EXTEND(sx : sx) - | WRAP - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_cvtop__Inn_1_Inn_2: `%%%`(Inn, Inn, cvtop__Inn_1_Inn_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Inn_1_Inn_2_case_0{Inn_1 : Inn, Inn_2 : Inn, sx : sx}: - `%%%`(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) < $sizenn2((Inn_2 : addrtype <: numtype))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Inn_1_Inn_2_case_1{Inn_1 : Inn, Inn_2 : Inn}: - `%%%`(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) > $sizenn2((Inn_2 : addrtype <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax cvtop__Inn_1_Fnn_2 = - | CONVERT(sx : sx) - | REINTERPRET - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn, Fnn, cvtop__Inn_1_Fnn_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Inn_1_Fnn_2_case_0{Inn_1 : Inn, Fnn_2 : Fnn, sx : sx}: - `%%%`(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Inn_1_Fnn_2_case_1{Inn_1 : Inn, Fnn_2 : Fnn}: - `%%%`(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) = $sizenn2((Fnn_2 : Fnn <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax cvtop__Fnn_1_Inn_2 = - | TRUNC(sx : sx) - | TRUNC_SAT(sx : sx) - | REINTERPRET - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn, Inn, cvtop__Fnn_1_Inn_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Fnn_1_Inn_2_case_0{Fnn_1 : Fnn, Inn_2 : Inn, sx : sx}: - `%%%`(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Fnn_1_Inn_2_case_1{Fnn_1 : Fnn, Inn_2 : Inn, sx : sx}: - `%%%`(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Fnn_1_Inn_2_case_2{Fnn_1 : Fnn, Inn_2 : Inn}: - `%%%`(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = $sizenn2((Inn_2 : addrtype <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax cvtop__Fnn_1_Fnn_2 = - | PROMOTE - | DEMOTE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn, Fnn, cvtop__Fnn_1_Fnn_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Fnn_1_Fnn_2_case_0{Fnn_1 : Fnn, Fnn_2 : Fnn}: - `%%%`(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) < $sizenn2((Fnn_2 : Fnn <: numtype))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop__Fnn_1_Fnn_2_case_1{Fnn_1 : Fnn, Fnn_2 : Fnn}: - `%%%`(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) > $sizenn2((Fnn_2 : Fnn <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax cvtop__ = - | mk_cvtop___0(Inn_1 : Inn, Inn_2 : Inn, var_x : cvtop__Inn_1_Inn_2) - | mk_cvtop___1(Inn_1 : Inn, Fnn_2 : Fnn, var_x : cvtop__Inn_1_Fnn_2) - | mk_cvtop___2(Fnn_1 : Fnn, Inn_2 : Inn, var_x : cvtop__Fnn_1_Inn_2) - | mk_cvtop___3(Fnn_1 : Fnn, Fnn_2 : Fnn, var_x : cvtop__Fnn_1_Fnn_2) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_cvtop__: `%%%`(numtype, numtype, cvtop__) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop___case_0{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Inn_2 : Inn, var_x : cvtop__Inn_1_Inn_2}: - `%%%`(numtype_1, numtype_2, mk_cvtop___0_cvtop__(Inn_1, Inn_2, var_x)) - -- wf_cvtop__Inn_1_Inn_2: `%%%`(Inn_1, Inn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop___case_1{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Fnn_2 : Fnn, var_x : cvtop__Inn_1_Fnn_2}: - `%%%`(numtype_1, numtype_2, mk_cvtop___1_cvtop__(Inn_1, Fnn_2, var_x)) - -- wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn_1, Fnn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop___case_2{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Inn_2 : Inn, var_x : cvtop__Fnn_1_Inn_2}: - `%%%`(numtype_1, numtype_2, mk_cvtop___2_cvtop__(Fnn_1, Inn_2, var_x)) - -- wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn_1, Inn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule cvtop___case_3{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Fnn_2 : Fnn, var_x : cvtop__Fnn_1_Fnn_2}: - `%%%`(numtype_1, numtype_2, mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, var_x)) - -- wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn_1, Fnn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_cvtop___0(var_x : cvtop__) : cvtop__Inn_1_Inn_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___0{Inn_1 : Inn, Inn_2 : Inn, var_x : cvtop__Inn_1_Inn_2}(mk_cvtop___0_cvtop__(Inn_1, Inn_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___0{var_x : cvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_cvtop___1(var_x : cvtop__) : cvtop__Inn_1_Fnn_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___1{Inn_1 : Inn, Fnn_2 : Fnn, var_x : cvtop__Inn_1_Fnn_2}(mk_cvtop___1_cvtop__(Inn_1, Fnn_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___1{var_x : cvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_cvtop___2(var_x : cvtop__) : cvtop__Fnn_1_Inn_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___2{Fnn_1 : Fnn, Inn_2 : Inn, var_x : cvtop__Fnn_1_Inn_2}(mk_cvtop___2_cvtop__(Fnn_1, Inn_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___2{var_x : cvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_cvtop___3(var_x : cvtop__) : cvtop__Fnn_1_Fnn_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___3{Fnn_1 : Fnn, Fnn_2 : Fnn, var_x : cvtop__Fnn_1_Fnn_2}(mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_cvtop___3{var_x : cvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax dim = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_dim: `%`(dim) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule dim_case_0{i : nat}: - `%`(`%`_dim(i)) - -- if (((((i = 1) \/ (i = 2)) \/ (i = 4)) \/ (i = 8)) \/ (i = 16)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax shape = - | `%X%`(lanetype : lanetype, dim : dim) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_shape: `%`(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule shape_case_0{lanetype : lanetype, dim : dim}: - `%`(`%X%`_shape(lanetype, dim)) - -- wf_dim: `%`(dim) - -- if (($lsize(lanetype) * dim!`%`_dim.0) = 128) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $dim(shape : shape) : dim - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $lanetype(shape : shape) : lanetype - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $lanetype{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = Lnn - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $unpackshape(shape : shape) : numtype - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $unpackshape{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = $lunpack(Lnn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax ishape = - | `%`(shape : shape) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_ishape: `%`(ishape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule ishape_case_0{Jnn : Jnn, shape : shape}: - `%`(`%`_ishape(shape)) - -- wf_shape: `%`(shape) - -- if ($lanetype(shape) = (Jnn : Jnn <: lanetype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax bshape = - | `%`(shape : shape) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_bshape: `%`(bshape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule bshape_case_0{shape : shape}: - `%`(`%`_bshape(shape)) - -- wf_shape: `%`(shape) - -- if ($lanetype(shape) = I8_lanetype) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax zero = - | ZERO - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax half = - | LOW - | HIGH - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vvunop = - | NOT - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vvbinop = - | AND - | ANDNOT - | OR - | XOR - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vvternop = - | BITSELECT - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vvtestop = - | ANY_TRUE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vunop_Jnn_M = - | ABS - | NEG - | POPCNT - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vunop_Jnn_M: `%%%`(Jnn, M, vunop_Jnn_M) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vunop_Jnn_M_case_0{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, ABS_vunop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vunop_Jnn_M_case_1{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, NEG_vunop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vunop_Jnn_M_case_2{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, POPCNT_vunop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 8) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vunop_Fnn_M = - | ABS - | NEG - | SQRT - | CEIL - | FLOOR - | TRUNC - | NEAREST - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vunop_ = - | mk_vunop__0(Jnn : Jnn, M : M, var_x : vunop_Jnn_M) - | mk_vunop__1(Fnn : Fnn, M : M, var_x : vunop_Fnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vunop_: `%%`(shape, vunop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vunop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vunop_Jnn_M}: - `%%`(shape, mk_vunop__0_vunop_(Jnn, M, var_x)) - -- wf_vunop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vunop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vunop_Fnn_M}: - `%%`(shape, mk_vunop__1_vunop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vunop__0(var_x : vunop_) : vunop_Jnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vunop__0{Jnn : Jnn, M : M, var_x : vunop_Jnn_M}(mk_vunop__0_vunop_(Jnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vunop__0{var_x : vunop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vunop__1(var_x : vunop_) : vunop_Fnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vunop__1{Fnn : Fnn, M : M, var_x : vunop_Fnn_M}(mk_vunop__1_vunop_(Fnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vunop__1{var_x : vunop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vbinop_Jnn_M = - | ADD - | SUB - | ADD_SAT(sx : sx) - | SUB_SAT(sx : sx) - | MUL - | AVGRU - | Q15MULR_SATS - | RELAXED_Q15MULRS - | MIN(sx : sx) - | MAX(sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vbinop_Jnn_M: `%%%`(Jnn, M, vbinop_Jnn_M) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_0{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, ADD_vbinop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_1{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, SUB_vbinop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_4{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, MUL_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) >= 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_5{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, AVGRU_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_6{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_7{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_8{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, MIN_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop_Jnn_M_case_9{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, MAX_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vbinop_Fnn_M = - | ADD - | SUB - | MUL - | DIV - | MIN - | MAX - | PMIN - | PMAX - | RELAXED_MIN - | RELAXED_MAX - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vbinop_ = - | mk_vbinop__0(Jnn : Jnn, M : M, var_x : vbinop_Jnn_M) - | mk_vbinop__1(Fnn : Fnn, M : M, var_x : vbinop_Fnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vbinop_: `%%`(shape, vbinop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vbinop_Jnn_M}: - `%%`(shape, mk_vbinop__0_vbinop_(Jnn, M, var_x)) - -- wf_vbinop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vbinop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vbinop_Fnn_M}: - `%%`(shape, mk_vbinop__1_vbinop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vbinop__0(var_x : vbinop_) : vbinop_Jnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vbinop__0{Jnn : Jnn, M : M, var_x : vbinop_Jnn_M}(mk_vbinop__0_vbinop_(Jnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vbinop__0{var_x : vbinop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vbinop__1(var_x : vbinop_) : vbinop_Fnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vbinop__1{Fnn : Fnn, M : M, var_x : vbinop_Fnn_M}(mk_vbinop__1_vbinop_(Fnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vbinop__1{var_x : vbinop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vternop_Jnn_M = - | RELAXED_LANESELECT - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vternop_Fnn_M = - | RELAXED_MADD - | RELAXED_NMADD - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vternop_ = - | mk_vternop__0(Jnn : Jnn, M : M, var_x : vternop_Jnn_M) - | mk_vternop__1(Fnn : Fnn, M : M, var_x : vternop_Fnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vternop_: `%%`(shape, vternop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vternop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vternop_Jnn_M}: - `%%`(shape, mk_vternop__0_vternop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vternop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vternop_Fnn_M}: - `%%`(shape, mk_vternop__1_vternop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vternop__0(var_x : vternop_) : vternop_Jnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vternop__0{Jnn : Jnn, M : M, var_x : vternop_Jnn_M}(mk_vternop__0_vternop_(Jnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vternop__0{var_x : vternop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vternop__1(var_x : vternop_) : vternop_Fnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vternop__1{Fnn : Fnn, M : M, var_x : vternop_Fnn_M}(mk_vternop__1_vternop_(Fnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vternop__1{var_x : vternop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vtestop_Jnn_M = - | ALL_TRUE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vtestop_ = - | mk_vtestop__0(Jnn : Jnn, M : M, var_x : vtestop_Jnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vtestop_: `%%`(shape, vtestop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vtestop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vtestop_Jnn_M}: - `%%`(shape, mk_vtestop__0_vtestop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vtestop__0(var_x : vtestop_) : vtestop_Jnn_M - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vtestop__0{Jnn : Jnn, M : M, var_x : vtestop_Jnn_M}(mk_vtestop__0_vtestop_(Jnn, M, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vrelop_Jnn_M = - | EQ - | NE - | LT(sx : sx) - | GT(sx : sx) - | LE(sx : sx) - | GE(sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vrelop_Jnn_M: `%%%`(Jnn, M, vrelop_Jnn_M) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_0{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, EQ_vrelop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_1{Jnn : Jnn, M : M}: - `%%%`(Jnn, M, NE_vrelop_Jnn_M) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, LT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, GT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_4{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, LE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop_Jnn_M_case_5{Jnn : Jnn, M : M, sx : sx}: - `%%%`(Jnn, M, GE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vrelop_Fnn_M = - | EQ - | NE - | LT - | GT - | LE - | GE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vrelop_ = - | mk_vrelop__0(Jnn : Jnn, M : M, var_x : vrelop_Jnn_M) - | mk_vrelop__1(Fnn : Fnn, M : M, var_x : vrelop_Fnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vrelop_: `%%`(shape, vrelop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vrelop_Jnn_M}: - `%%`(shape, mk_vrelop__0_vrelop_(Jnn, M, var_x)) - -- wf_vrelop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vrelop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vrelop_Fnn_M}: - `%%`(shape, mk_vrelop__1_vrelop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vrelop__0(var_x : vrelop_) : vrelop_Jnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vrelop__0{Jnn : Jnn, M : M, var_x : vrelop_Jnn_M}(mk_vrelop__0_vrelop_(Jnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vrelop__0{var_x : vrelop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vrelop__1(var_x : vrelop_) : vrelop_Fnn_M? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vrelop__1{Fnn : Fnn, M : M, var_x : vrelop_Fnn_M}(mk_vrelop__1_vrelop_(Fnn, M, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vrelop__1{var_x : vrelop_}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vshiftop_Jnn_M = - | SHL - | SHR(sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vshiftop_ = - | mk_vshiftop__0(Jnn : Jnn, M : M, var_x : vshiftop_Jnn_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vshiftop_: `%%`(ishape, vshiftop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vshiftop__case_0{ishape : ishape, Jnn : Jnn, M : M, var_x : vshiftop_Jnn_M}: - `%%`(ishape, mk_vshiftop__0_vshiftop_(Jnn, M, var_x)) - -- if (ishape = `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vshiftop__0(var_x : vshiftop_) : vshiftop_Jnn_M - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vshiftop__0{Jnn : Jnn, M : M, var_x : vshiftop_Jnn_M}(mk_vshiftop__0_vshiftop_(Jnn, M, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vswizzlop_M = - | SWIZZLE - | RELAXED_SWIZZLE - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vswizzlop_ = - | mk_vswizzlop__0(M : M, var_x : vswizzlop_M) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vswizzlop_: `%%`(bshape, vswizzlop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vswizzlop__case_0{bshape : bshape, M : M, var_x : vswizzlop_M}: - `%%`(bshape, mk_vswizzlop__0_vswizzlop_(M, var_x)) - -- if (bshape = `%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vswizzlop__0(var_x : vswizzlop_) : vswizzlop_M - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vswizzlop__0{M : M, var_x : vswizzlop_M}(mk_vswizzlop__0_vswizzlop_(M, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextunop__Jnn_1_M_1_Jnn_2_M_2 = - | EXTADD_PAIRWISE(sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextunop__Jnn_1_M_1_Jnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextunop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)) - -- if ((16 <= (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) <= 32))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextunop__ = - | mk_vextunop___0(Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextunop__: `%%%`(ishape, ishape, vextunop__) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextunop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2}: - `%%%`(ishape_1, ishape_2, mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) - -- wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vextunop___0(var_x : vextunop__) : vextunop__Jnn_1_M_1_Jnn_2_M_2 - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vextunop___0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2}(mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextbinop__Jnn_1_M_1_Jnn_2_M_2 = - | EXTMUL(half : half, sx : sx) - | DOTS - | RELAXED_DOTS - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextbinop__Jnn_1_M_1_Jnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) >= 16)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_1{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_2{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 16)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextbinop__ = - | mk_vextbinop___0(Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextbinop__: `%%%`(ishape, ishape, vextbinop__) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextbinop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2}: - `%%%`(ishape_1, ishape_2, mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) - -- wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vextbinop___0(var_x : vextbinop__) : vextbinop__Jnn_1_M_1_Jnn_2_M_2 - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vextbinop___0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2}(mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextternop__Jnn_1_M_1_Jnn_2_M_2 = - | RELAXED_DOT_ADDS - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextternop__Jnn_1_M_1_Jnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextternop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((4 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vextternop__ = - | mk_vextternop___0(Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vextternop__: `%%%`(ishape, ishape, vextternop__) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vextternop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2}: - `%%%`(ishape_1, ishape_2, mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) - -- wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vextternop___0(var_x : vextternop__) : vextternop__Jnn_1_M_1_Jnn_2_M_2 - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vextternop___0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2}(mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vcvtop__Jnn_1_M_1_Jnn_2_M_2 = - | EXTEND(half : half, sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vcvtop__Jnn_1_M_1_Jnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: - `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vcvtop__Jnn_1_M_1_Fnn_2_M_2 = - | CONVERT(`half?` : half?, sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn, M, Fnn, M, vcvtop__Jnn_1_M_1_Fnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Jnn_1_M_1_Fnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, `half?` : half?, sx : sx}: - `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(`half?`, sx)) - -- if (((($sizenn2((Fnn_2 : Fnn <: numtype)) = $lsizenn1((Jnn_1 : Jnn <: lanetype))) /\ ($lsizenn1((Jnn_1 : Jnn <: lanetype)) = 32)) /\ (half?{half <- `half?`} = ?())) \/ (($sizenn2((Fnn_2 : Fnn <: numtype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (half?{half <- `half?`} = ?(LOW_half)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vcvtop__Fnn_1_M_1_Jnn_2_M_2 = - | TRUNC_SAT(sx : sx, `zero?` : zero?) - | RELAXED_TRUNC(sx : sx, `zero?` : zero?) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn, M, Jnn, M, vcvtop__Fnn_1_M_1_Jnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: - `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: - `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vcvtop__Fnn_1_M_1_Fnn_2_M_2 = - | DEMOTE(zero : zero) - | PROMOTELOW - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn, M, Fnn, M, vcvtop__Fnn_1_M_1_Fnn_2_M_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, zero : zero}: - `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $sizenn2((Fnn_2 : Fnn <: numtype)))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M}: - `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2) - -- if ((2 * $sizenn1((Fnn_1 : Fnn <: numtype))) = $sizenn2((Fnn_2 : Fnn <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vcvtop__ = - | mk_vcvtop___0(Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2) - | mk_vcvtop___1(Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2) - | mk_vcvtop___2(Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2) - | mk_vcvtop___3(Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vcvtop__: `%%%`(shape, shape, vcvtop__) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop___case_0{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2}: - `%%%`(shape_1, shape_2, mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) - -- wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop___case_1{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2}: - `%%%`(shape_1, shape_2, mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, var_x)) - -- wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop___case_2{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2}: - `%%%`(shape_1, shape_2, mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, var_x)) - -- wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vcvtop___case_3{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2}: - `%%%`(shape_1, shape_2, mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, var_x)) - -- wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vcvtop___0(var_x : vcvtop__) : vcvtop__Jnn_1_M_1_Jnn_2_M_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2}(mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___0{var_x : vcvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vcvtop___1(var_x : vcvtop__) : vcvtop__Jnn_1_M_1_Fnn_2_M_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___1{Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2}(mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___1{var_x : vcvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vcvtop___2(var_x : vcvtop__) : vcvtop__Fnn_1_M_1_Jnn_2_M_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___2{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2}(mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___2{var_x : vcvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_vcvtop___3(var_x : vcvtop__) : vcvtop__Fnn_1_M_1_Fnn_2_M_2? - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___3{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2}(mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, var_x)) = ?(var_x) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_vcvtop___3{var_x : vcvtop__}(var_x) = ?() - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax memarg = -{ - ALIGN u32, - OFFSET u64 -} - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_memarg: `%`(memarg) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule memarg_case_{var_0 : u32, var_1 : u64}: - `%`({ALIGN var_0, OFFSET var_1}) - -- wf_uN: `%%`(32, var_0) - -- wf_uN: `%%`(64, var_1) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax loadop_Inn = - | `%_%`(sz : sz, sx : sx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_loadop_Inn: `%%`(Inn, loadop_Inn) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule loadop_Inn_case_0{Inn : Inn, sz : sz, sx : sx}: - `%%`(Inn, `%_%`_loadop_Inn(sz, sx)) - -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax loadop_ = - | mk_loadop__0(Inn : Inn, var_x : loadop_Inn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_loadop_: `%%`(numtype, loadop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule loadop__case_0{numtype : numtype, Inn : Inn, var_x : loadop_Inn}: - `%%`(numtype, mk_loadop__0_loadop_(Inn, var_x)) - -- wf_loadop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_loadop__0(var_x : loadop_) : loadop_Inn - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_loadop__0{Inn : Inn, var_x : loadop_Inn}(mk_loadop__0_loadop_(Inn, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax storeop_Inn = - | `%`(sz : sz) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_storeop_Inn: `%%`(Inn, storeop_Inn) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule storeop_Inn_case_0{Inn : Inn, sz : sz}: - `%%`(Inn, `%`_storeop_Inn(sz)) - -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax storeop_ = - | mk_storeop__0(Inn : Inn, var_x : storeop_Inn) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_storeop_: `%%`(numtype, storeop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule storeop__case_0{numtype : numtype, Inn : Inn, var_x : storeop_Inn}: - `%%`(numtype, mk_storeop__0_storeop_(Inn, var_x)) - -- wf_storeop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $proj_storeop__0(var_x : storeop_) : storeop_Inn - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_storeop__0{Inn : Inn, var_x : storeop_Inn}(mk_storeop__0_storeop_(Inn, var_x)) = var_x - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax vloadop_ = - | `SHAPE%X%_%`(sz : sz, M : M, sx : sx) - | SPLAT(sz : sz) - | ZERO(sz : sz) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_vloadop_: `%%`(vectype, vloadop_) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vloadop__case_0{vectype : vectype, sz : sz, M : M, sx : sx}: - `%%`(vectype, `SHAPE%X%_%`_vloadop_(sz, M, sx)) - -- wf_sz: `%`(sz) - -- if (((sz!`%`_sz.0 * M) : nat <:> rat) = (($vsize(vectype) : nat <:> rat) / (2 : nat <:> rat))) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vloadop__case_1{vectype : vectype, sz : sz}: - `%%`(vectype, SPLAT_vloadop_(sz)) - -- wf_sz: `%`(sz) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule vloadop__case_2{vectype : vectype, sz : sz}: - `%%`(vectype, ZERO_vloadop_(sz)) - -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 >= 32) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax blocktype = - | _RESULT(`valtype?` : valtype?) - | _IDX(typeidx : typeidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_blocktype: `%`(blocktype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule blocktype_case_0{`valtype?` : valtype?}: - `%`(_RESULT_blocktype(`valtype?`)) - -- (wf_valtype: `%`(valtype))?{valtype <- `valtype?`} - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule blocktype_case_1{typeidx : typeidx}: - `%`(_IDX_blocktype(typeidx)) - -- wf_uN: `%%`(32, typeidx) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax addr = nat - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayaddr = addr - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax catch = - | CATCH(tagidx : tagidx, labelidx : labelidx) - | CATCH_REF(tagidx : tagidx, labelidx : labelidx) - | CATCH_ALL(labelidx : labelidx) - | CATCH_ALL_REF(labelidx : labelidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -relation wf_catch: `%`(catch) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule catch_case_0{tagidx : tagidx, labelidx : labelidx}: - `%`(CATCH_catch(tagidx, labelidx)) - -- wf_uN: `%%`(32, tagidx) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule catch_case_1{tagidx : tagidx, labelidx : labelidx}: - `%`(CATCH_REF_catch(tagidx, labelidx)) - -- wf_uN: `%%`(32, tagidx) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule catch_case_2{labelidx : labelidx}: - `%`(CATCH_ALL_catch(labelidx)) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - rule catch_case_3{labelidx : labelidx}: - `%`(CATCH_ALL_REF_catch(labelidx)) - -- wf_uN: `%%`(32, labelidx) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exnaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax dataaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax elemaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funcaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax globaladdr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax memaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax tableaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax tagaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax externaddr = - | TAG(tagaddr : tagaddr) - | GLOBAL(globaladdr : globaladdr) - | MEM(memaddr : memaddr) - | TABLE(tableaddr : tableaddr) - | FUNC(funcaddr : funcaddr) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exportinst = -{ - NAME name, - ADDR externaddr -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_exportinst: `%`(exportinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule exportinst_case_{var_0 : name, var_1 : externaddr}: - `%`({NAME var_0, ADDR var_1}) - -- wf_name: `%`(var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax moduleinst = -{ - TYPES deftype*, - TAGS tagaddr*, - GLOBALS globaladdr*, - MEMS memaddr*, - TABLES tableaddr*, - FUNCS funcaddr*, - DATAS dataaddr*, - ELEMS elemaddr*, - EXPORTS exportinst* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_moduleinst: `%`(moduleinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule moduleinst_case_{var_0 : deftype*, var_1 : tagaddr*, var_2 : globaladdr*, var_3 : memaddr*, var_4 : tableaddr*, var_5 : funcaddr*, var_6 : dataaddr*, var_7 : elemaddr*, var_8 : exportinst*}: - `%`({TYPES var_0, TAGS var_1, GLOBALS var_2, MEMS var_3, TABLES var_4, FUNCS var_5, DATAS var_6, ELEMS var_7, EXPORTS var_8}) - -- (wf_exportinst: `%`(var_8))*{var_8 <- var_8} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax hostaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structaddr = addr - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.1-43.19 -syntax ref = - | `REF.I31_NUM`(u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(structaddr : structaddr) - | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(funcaddr : funcaddr) - | `REF.EXN_ADDR`(exnaddr : exnaddr) - | `REF.HOST_ADDR`(hostaddr : hostaddr) - | `REF.EXTERN`(ref : ref) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 -relation wf_ref: `%`(ref) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_0{u31 : u31}: - `%`(`REF.I31_NUM`_ref(u31)) - -- wf_uN: `%%`(31, u31) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_1: - `%`(`REF.NULL_ADDR`_ref) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_2{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_ref(structaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_3{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_ref(arrayaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_4{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_ref(funcaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_5{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_ref(exnaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_6{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_ref(hostaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 - rule ref_case_7{ref : ref}: - `%`(`REF.EXTERN`_ref(ref)) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax val = - | CONST(numtype : numtype, num_) - | VCONST(vectype : vectype, vec_) - | `REF.I31_NUM`(u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(structaddr : structaddr) - | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(funcaddr : funcaddr) - | `REF.EXN_ADDR`(exnaddr : exnaddr) - | `REF.HOST_ADDR`(hostaddr : hostaddr) - | `REF.EXTERN`(ref : ref) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_val: `%`(val) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_0{numtype : numtype, var_0 : num_}: - `%`(CONST_val(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_1{vectype : vectype, var_0 : vec_}: - `%`(VCONST_val(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_2{u31 : u31}: - `%`(`REF.I31_NUM`_val(u31)) - -- wf_uN: `%%`(31, u31) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_3: - `%`(`REF.NULL_ADDR`_val) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_4{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_val(structaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_5{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_val(arrayaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_6{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_val(funcaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_7{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_val(exnaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_8{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_val(hostaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule val_case_9{ref : ref}: - `%`(`REF.EXTERN`_val(ref)) - -- wf_ref: `%`(ref) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax frame = -{ - LOCALS val?*, - MODULE moduleinst -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_frame: `%`(frame) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule frame_case_{var_0 : val?*, var_1 : moduleinst}: - `%`({LOCALS var_0, MODULE var_1}) - -- (wf_val: `%`(var_0))?{var_0 <- var_0}*{var_0 <- var_0} - -- wf_moduleinst: `%`(var_1) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.1-139.9 -syntax instr = - | NOP - | UNREACHABLE - | DROP - | SELECT(`valtype*?` : valtype*?) - | BLOCK(blocktype : blocktype, `instr*` : instr*) - | LOOP(blocktype : blocktype, `instr*` : instr*) - | `IF%%ELSE%`(blocktype : blocktype, `instr*` : instr*, `instr*` : instr*) - | BR(labelidx : labelidx) - | BR_IF(labelidx : labelidx) - | BR_TABLE(`labelidx*` : labelidx*, labelidx : labelidx) - | BR_ON_NULL(labelidx : labelidx) - | BR_ON_NON_NULL(labelidx : labelidx) - | BR_ON_CAST(labelidx : labelidx, reftype : reftype, reftype : reftype) - | BR_ON_CAST_FAIL(labelidx : labelidx, reftype : reftype, reftype : reftype) - | CALL(funcidx : funcidx) - | CALL_REF(typeuse : typeuse) - | CALL_INDIRECT(tableidx : tableidx, typeuse : typeuse) - | RETURN - | RETURN_CALL(funcidx : funcidx) - | RETURN_CALL_REF(typeuse : typeuse) - | RETURN_CALL_INDIRECT(tableidx : tableidx, typeuse : typeuse) - | THROW(tagidx : tagidx) - | THROW_REF - | TRY_TABLE(blocktype : blocktype, list(syntax catch), `instr*` : instr*) - | `LOCAL.GET`(localidx : localidx) - | `LOCAL.SET`(localidx : localidx) - | `LOCAL.TEE`(localidx : localidx) - | `GLOBAL.GET`(globalidx : globalidx) - | `GLOBAL.SET`(globalidx : globalidx) - | `TABLE.GET`(tableidx : tableidx) - | `TABLE.SET`(tableidx : tableidx) - | `TABLE.SIZE`(tableidx : tableidx) - | `TABLE.GROW`(tableidx : tableidx) - | `TABLE.FILL`(tableidx : tableidx) - | `TABLE.COPY`(tableidx : tableidx, tableidx : tableidx) - | `TABLE.INIT`(tableidx : tableidx, elemidx : elemidx) - | `ELEM.DROP`(elemidx : elemidx) - | LOAD(numtype : numtype, loadop_?, memidx : memidx, memarg : memarg) - | STORE(numtype : numtype, storeop_?, memidx : memidx, memarg : memarg) - | VLOAD(vectype : vectype, vloadop_?, memidx : memidx, memarg : memarg) - | VLOAD_LANE(vectype : vectype, sz : sz, memidx : memidx, memarg : memarg, laneidx : laneidx) - | VSTORE(vectype : vectype, memidx : memidx, memarg : memarg) - | VSTORE_LANE(vectype : vectype, sz : sz, memidx : memidx, memarg : memarg, laneidx : laneidx) - | `MEMORY.SIZE`(memidx : memidx) - | `MEMORY.GROW`(memidx : memidx) - | `MEMORY.FILL`(memidx : memidx) - | `MEMORY.COPY`(memidx : memidx, memidx : memidx) - | `MEMORY.INIT`(memidx : memidx, dataidx : dataidx) - | `DATA.DROP`(dataidx : dataidx) - | `REF.NULL`(heaptype : heaptype) - | `REF.IS_NULL` - | `REF.AS_NON_NULL` - | `REF.EQ` - | `REF.TEST`(reftype : reftype) - | `REF.CAST`(reftype : reftype) - | `REF.FUNC`(funcidx : funcidx) - | `REF.I31` - | `I31.GET`(sx : sx) - | `STRUCT.NEW`(typeidx : typeidx) - | `STRUCT.NEW_DEFAULT`(typeidx : typeidx) - | `STRUCT.GET`(`sx?` : sx?, typeidx : typeidx, fieldidx : fieldidx) - | `STRUCT.SET`(typeidx : typeidx, fieldidx : fieldidx) - | `ARRAY.NEW`(typeidx : typeidx) - | `ARRAY.NEW_DEFAULT`(typeidx : typeidx) - | `ARRAY.NEW_FIXED`(typeidx : typeidx, u32 : u32) - | `ARRAY.NEW_DATA`(typeidx : typeidx, dataidx : dataidx) - | `ARRAY.NEW_ELEM`(typeidx : typeidx, elemidx : elemidx) - | `ARRAY.GET`(`sx?` : sx?, typeidx : typeidx) - | `ARRAY.SET`(typeidx : typeidx) - | `ARRAY.LEN` - | `ARRAY.FILL`(typeidx : typeidx) - | `ARRAY.COPY`(typeidx : typeidx, typeidx : typeidx) - | `ARRAY.INIT_DATA`(typeidx : typeidx, dataidx : dataidx) - | `ARRAY.INIT_ELEM`(typeidx : typeidx, elemidx : elemidx) - | `EXTERN.CONVERT_ANY` - | `ANY.CONVERT_EXTERN` - | CONST(numtype : numtype, num_) - | UNOP(numtype : numtype, unop_) - | BINOP(numtype : numtype, binop_) - | TESTOP(numtype : numtype, testop_) - | RELOP(numtype : numtype, relop_) - | CVTOP(numtype_1 : numtype, numtype_2 : numtype, cvtop__) - | VCONST(vectype : vectype, vec_) - | VVUNOP(vectype : vectype, vvunop : vvunop) - | VVBINOP(vectype : vectype, vvbinop : vvbinop) - | VVTERNOP(vectype : vectype, vvternop : vvternop) - | VVTESTOP(vectype : vectype, vvtestop : vvtestop) - | VUNOP(shape : shape, vunop_) - | VBINOP(shape : shape, vbinop_) - | VTERNOP(shape : shape, vternop_) - | VTESTOP(shape : shape, vtestop_) - | VRELOP(shape : shape, vrelop_) - | VSHIFTOP(ishape : ishape, vshiftop_) - | VBITMASK(ishape : ishape) - | VSWIZZLOP(bshape : bshape, vswizzlop_) - | VSHUFFLE(bshape : bshape, `laneidx*` : laneidx*) - | VEXTUNOP(ishape_1 : ishape, ishape_2 : ishape, vextunop__) - | VEXTBINOP(ishape_1 : ishape, ishape_2 : ishape, vextbinop__) - | VEXTTERNOP(ishape_1 : ishape, ishape_2 : ishape, vextternop__) - | VNARROW(ishape_1 : ishape, ishape_2 : ishape, sx : sx) - | VCVTOP(shape_1 : shape, shape_2 : shape, vcvtop__) - | VSPLAT(shape : shape) - | VEXTRACT_LANE(shape : shape, `sx?` : sx?, laneidx : laneidx) - | VREPLACE_LANE(shape : shape, laneidx : laneidx) - | `REF.I31_NUM`(u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(structaddr : structaddr) - | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(funcaddr : funcaddr) - | `REF.EXN_ADDR`(exnaddr : exnaddr) - | `REF.HOST_ADDR`(hostaddr : hostaddr) - | `REF.EXTERN`(ref : ref) - | `LABEL_%{%}%`(n : n, `instr*` : instr*, `instr*` : instr*) - | `FRAME_%{%}%`(n : n, frame : frame, `instr*` : instr*) - | `HANDLER_%{%}%`(n : n, `catch*` : catch*, `instr*` : instr*) - | TRAP -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 -relation wf_instr: `%`(instr) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_0: - `%`(NOP_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_1: - `%`(UNREACHABLE_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_2: - `%`(DROP_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_3{`valtype*?` : valtype*?}: - `%`(SELECT_instr(`valtype*?`)) - -- (wf_valtype: `%`(valtype))*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_4{blocktype : blocktype, `instr*` : instr*}: - `%`(BLOCK_instr(blocktype, `instr*`)) - -- wf_blocktype: `%`(blocktype) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_5{blocktype : blocktype, `instr*` : instr*}: - `%`(LOOP_instr(blocktype, `instr*`)) - -- wf_blocktype: `%`(blocktype) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_6{blocktype : blocktype, `instr*` : instr*, `instr*_0` : instr*}: - `%`(`IF%%ELSE%`_instr(blocktype, `instr*`, `instr*_0`)) - -- wf_blocktype: `%`(blocktype) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- (wf_instr: `%`(`instr*_0`))*{`instr*_0` <- `instr*_0`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_7{labelidx : labelidx}: - `%`(BR_instr(labelidx)) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_8{labelidx : labelidx}: - `%`(BR_IF_instr(labelidx)) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_9{`labelidx*` : labelidx*, labelidx : labelidx}: - `%`(BR_TABLE_instr(`labelidx*`, labelidx)) - -- (wf_uN: `%%`(32, labelidx))*{labelidx <- `labelidx*`} - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_10{labelidx : labelidx}: - `%`(BR_ON_NULL_instr(labelidx)) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_11{labelidx : labelidx}: - `%`(BR_ON_NON_NULL_instr(labelidx)) - -- wf_uN: `%%`(32, labelidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_12{labelidx : labelidx, reftype : reftype, reftype_0 : reftype}: - `%`(BR_ON_CAST_instr(labelidx, reftype, reftype_0)) - -- wf_uN: `%%`(32, labelidx) - -- wf_reftype: `%`(reftype) - -- wf_reftype: `%`(reftype_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_13{labelidx : labelidx, reftype : reftype, reftype_0 : reftype}: - `%`(BR_ON_CAST_FAIL_instr(labelidx, reftype, reftype_0)) - -- wf_uN: `%%`(32, labelidx) - -- wf_reftype: `%`(reftype) - -- wf_reftype: `%`(reftype_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_14{funcidx : funcidx}: - `%`(CALL_instr(funcidx)) - -- wf_uN: `%%`(32, funcidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_15{typeuse : typeuse}: - `%`(CALL_REF_instr(typeuse)) - -- wf_typeuse: `%`(typeuse) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_16{tableidx : tableidx, typeuse : typeuse}: - `%`(CALL_INDIRECT_instr(tableidx, typeuse)) - -- wf_uN: `%%`(32, tableidx) - -- wf_typeuse: `%`(typeuse) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_17: - `%`(RETURN_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_18{funcidx : funcidx}: - `%`(RETURN_CALL_instr(funcidx)) - -- wf_uN: `%%`(32, funcidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_19{typeuse : typeuse}: - `%`(RETURN_CALL_REF_instr(typeuse)) - -- wf_typeuse: `%`(typeuse) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_20{tableidx : tableidx, typeuse : typeuse}: - `%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse)) - -- wf_uN: `%%`(32, tableidx) - -- wf_typeuse: `%`(typeuse) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_21{tagidx : tagidx}: - `%`(THROW_instr(tagidx)) - -- wf_uN: `%%`(32, tagidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_22: - `%`(THROW_REF_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_23{blocktype : blocktype, var_0 : list(syntax catch), `instr*` : instr*}: - `%`(TRY_TABLE_instr(blocktype, var_0, `instr*`)) - -- wf_blocktype: `%`(blocktype) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_24{localidx : localidx}: - `%`(`LOCAL.GET`_instr(localidx)) - -- wf_uN: `%%`(32, localidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_25{localidx : localidx}: - `%`(`LOCAL.SET`_instr(localidx)) - -- wf_uN: `%%`(32, localidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_26{localidx : localidx}: - `%`(`LOCAL.TEE`_instr(localidx)) - -- wf_uN: `%%`(32, localidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_27{globalidx : globalidx}: - `%`(`GLOBAL.GET`_instr(globalidx)) - -- wf_uN: `%%`(32, globalidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_28{globalidx : globalidx}: - `%`(`GLOBAL.SET`_instr(globalidx)) - -- wf_uN: `%%`(32, globalidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_29{tableidx : tableidx}: - `%`(`TABLE.GET`_instr(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_30{tableidx : tableidx}: - `%`(`TABLE.SET`_instr(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_31{tableidx : tableidx}: - `%`(`TABLE.SIZE`_instr(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_32{tableidx : tableidx}: - `%`(`TABLE.GROW`_instr(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_33{tableidx : tableidx}: - `%`(`TABLE.FILL`_instr(tableidx)) - -- wf_uN: `%%`(32, tableidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_34{tableidx : tableidx, tableidx_0 : tableidx}: - `%`(`TABLE.COPY`_instr(tableidx, tableidx_0)) - -- wf_uN: `%%`(32, tableidx) - -- wf_uN: `%%`(32, tableidx_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_35{tableidx : tableidx, elemidx : elemidx}: - `%`(`TABLE.INIT`_instr(tableidx, elemidx)) - -- wf_uN: `%%`(32, tableidx) - -- wf_uN: `%%`(32, elemidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_36{elemidx : elemidx}: - `%`(`ELEM.DROP`_instr(elemidx)) - -- wf_uN: `%%`(32, elemidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_37{numtype : numtype, var_0 : loadop_?, memidx : memidx, memarg : memarg}: - `%`(LOAD_instr(numtype, var_0, memidx, memarg)) - -- (wf_loadop_: `%%`(numtype, var_0))?{var_0 <- var_0} - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_38{numtype : numtype, var_0 : storeop_?, memidx : memidx, memarg : memarg}: - `%`(STORE_instr(numtype, var_0, memidx, memarg)) - -- (wf_storeop_: `%%`(numtype, var_0))?{var_0 <- var_0} - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_39{vectype : vectype, var_0 : vloadop_?, memidx : memidx, memarg : memarg}: - `%`(VLOAD_instr(vectype, var_0, memidx, memarg)) - -- (wf_vloadop_: `%%`(vectype, var_0))?{var_0 <- var_0} - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_40{vectype : vectype, sz : sz, memidx : memidx, memarg : memarg, laneidx : laneidx}: - `%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx)) - -- wf_sz: `%`(sz) - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - -- wf_uN: `%%`(8, laneidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_41{vectype : vectype, memidx : memidx, memarg : memarg}: - `%`(VSTORE_instr(vectype, memidx, memarg)) - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_42{vectype : vectype, sz : sz, memidx : memidx, memarg : memarg, laneidx : laneidx}: - `%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx)) - -- wf_sz: `%`(sz) - -- wf_uN: `%%`(32, memidx) - -- wf_memarg: `%`(memarg) - -- wf_uN: `%%`(8, laneidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_43{memidx : memidx}: - `%`(`MEMORY.SIZE`_instr(memidx)) - -- wf_uN: `%%`(32, memidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_44{memidx : memidx}: - `%`(`MEMORY.GROW`_instr(memidx)) - -- wf_uN: `%%`(32, memidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_45{memidx : memidx}: - `%`(`MEMORY.FILL`_instr(memidx)) - -- wf_uN: `%%`(32, memidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_46{memidx : memidx, memidx_0 : memidx}: - `%`(`MEMORY.COPY`_instr(memidx, memidx_0)) - -- wf_uN: `%%`(32, memidx) - -- wf_uN: `%%`(32, memidx_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_47{memidx : memidx, dataidx : dataidx}: - `%`(`MEMORY.INIT`_instr(memidx, dataidx)) - -- wf_uN: `%%`(32, memidx) - -- wf_uN: `%%`(32, dataidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_48{dataidx : dataidx}: - `%`(`DATA.DROP`_instr(dataidx)) - -- wf_uN: `%%`(32, dataidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_49{heaptype : heaptype}: - `%`(`REF.NULL`_instr(heaptype)) - -- wf_heaptype: `%`(heaptype) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_50: - `%`(`REF.IS_NULL`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_51: - `%`(`REF.AS_NON_NULL`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_52: - `%`(`REF.EQ`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_53{reftype : reftype}: - `%`(`REF.TEST`_instr(reftype)) - -- wf_reftype: `%`(reftype) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_54{reftype : reftype}: - `%`(`REF.CAST`_instr(reftype)) - -- wf_reftype: `%`(reftype) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_55{funcidx : funcidx}: - `%`(`REF.FUNC`_instr(funcidx)) - -- wf_uN: `%%`(32, funcidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_56: - `%`(`REF.I31`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_57{sx : sx}: - `%`(`I31.GET`_instr(sx)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_58{typeidx : typeidx}: - `%`(`STRUCT.NEW`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_59{typeidx : typeidx}: - `%`(`STRUCT.NEW_DEFAULT`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_60{`sx?` : sx?, typeidx : typeidx, fieldidx : fieldidx}: - `%`(`STRUCT.GET`_instr(`sx?`, typeidx, fieldidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, fieldidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_61{typeidx : typeidx, fieldidx : fieldidx}: - `%`(`STRUCT.SET`_instr(typeidx, fieldidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, fieldidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_62{typeidx : typeidx}: - `%`(`ARRAY.NEW`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_63{typeidx : typeidx}: - `%`(`ARRAY.NEW_DEFAULT`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_64{typeidx : typeidx, u32 : u32}: - `%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, u32) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_65{typeidx : typeidx, dataidx : dataidx}: - `%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, dataidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_66{typeidx : typeidx, elemidx : elemidx}: - `%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, elemidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_67{`sx?` : sx?, typeidx : typeidx}: - `%`(`ARRAY.GET`_instr(`sx?`, typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_68{typeidx : typeidx}: - `%`(`ARRAY.SET`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_69: - `%`(`ARRAY.LEN`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_70{typeidx : typeidx}: - `%`(`ARRAY.FILL`_instr(typeidx)) - -- wf_uN: `%%`(32, typeidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_71{typeidx : typeidx, typeidx_0 : typeidx}: - `%`(`ARRAY.COPY`_instr(typeidx, typeidx_0)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, typeidx_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_72{typeidx : typeidx, dataidx : dataidx}: - `%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, dataidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_73{typeidx : typeidx, elemidx : elemidx}: - `%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) - -- wf_uN: `%%`(32, typeidx) - -- wf_uN: `%%`(32, elemidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_74: - `%`(`EXTERN.CONVERT_ANY`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_75: - `%`(`ANY.CONVERT_EXTERN`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_76{numtype : numtype, var_0 : num_}: - `%`(CONST_instr(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_77{numtype : numtype, var_0 : unop_}: - `%`(UNOP_instr(numtype, var_0)) - -- wf_unop_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_78{numtype : numtype, var_0 : binop_}: - `%`(BINOP_instr(numtype, var_0)) - -- wf_binop_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_79{numtype : numtype, var_0 : testop_}: - `%`(TESTOP_instr(numtype, var_0)) - -- wf_testop_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_80{numtype : numtype, var_0 : relop_}: - `%`(RELOP_instr(numtype, var_0)) - -- wf_relop_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_81{numtype_1 : numtype, numtype_2 : numtype, var_0 : cvtop__}: - `%`(CVTOP_instr(numtype_1, numtype_2, var_0)) - -- wf_cvtop__: `%%%`(numtype_2, numtype_1, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_82{vectype : vectype, var_0 : vec_}: - `%`(VCONST_instr(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_83{vectype : vectype, vvunop : vvunop}: - `%`(VVUNOP_instr(vectype, vvunop)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_84{vectype : vectype, vvbinop : vvbinop}: - `%`(VVBINOP_instr(vectype, vvbinop)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_85{vectype : vectype, vvternop : vvternop}: - `%`(VVTERNOP_instr(vectype, vvternop)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_86{vectype : vectype, vvtestop : vvtestop}: - `%`(VVTESTOP_instr(vectype, vvtestop)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_87{shape : shape, var_0 : vunop_}: - `%`(VUNOP_instr(shape, var_0)) - -- wf_shape: `%`(shape) - -- wf_vunop_: `%%`(shape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_88{shape : shape, var_0 : vbinop_}: - `%`(VBINOP_instr(shape, var_0)) - -- wf_shape: `%`(shape) - -- wf_vbinop_: `%%`(shape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_89{shape : shape, var_0 : vternop_}: - `%`(VTERNOP_instr(shape, var_0)) - -- wf_shape: `%`(shape) - -- wf_vternop_: `%%`(shape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_90{shape : shape, var_0 : vtestop_}: - `%`(VTESTOP_instr(shape, var_0)) - -- wf_shape: `%`(shape) - -- wf_vtestop_: `%%`(shape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_91{shape : shape, var_0 : vrelop_}: - `%`(VRELOP_instr(shape, var_0)) - -- wf_shape: `%`(shape) - -- wf_vrelop_: `%%`(shape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_92{ishape : ishape, var_0 : vshiftop_}: - `%`(VSHIFTOP_instr(ishape, var_0)) - -- wf_ishape: `%`(ishape) - -- wf_vshiftop_: `%%`(ishape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_93{ishape : ishape}: - `%`(VBITMASK_instr(ishape)) - -- wf_ishape: `%`(ishape) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_94{bshape : bshape, var_0 : vswizzlop_}: - `%`(VSWIZZLOP_instr(bshape, var_0)) - -- wf_bshape: `%`(bshape) - -- wf_vswizzlop_: `%%`(bshape, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_95{bshape : bshape, `laneidx*` : laneidx*}: - `%`(VSHUFFLE_instr(bshape, `laneidx*`)) - -- wf_bshape: `%`(bshape) - -- (wf_uN: `%%`(8, laneidx))*{laneidx <- `laneidx*`} - -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = $dim(bshape!`%`_bshape.0)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_96{ishape_1 : ishape, ishape_2 : ishape, var_0 : vextunop__}: - `%`(VEXTUNOP_instr(ishape_1, ishape_2, var_0)) - -- wf_ishape: `%`(ishape_1) - -- wf_ishape: `%`(ishape_2) - -- wf_vextunop__: `%%%`(ishape_2, ishape_1, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_97{ishape_1 : ishape, ishape_2 : ishape, var_0 : vextbinop__}: - `%`(VEXTBINOP_instr(ishape_1, ishape_2, var_0)) - -- wf_ishape: `%`(ishape_1) - -- wf_ishape: `%`(ishape_2) - -- wf_vextbinop__: `%%%`(ishape_2, ishape_1, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_98{ishape_1 : ishape, ishape_2 : ishape, var_0 : vextternop__}: - `%`(VEXTTERNOP_instr(ishape_1, ishape_2, var_0)) - -- wf_ishape: `%`(ishape_1) - -- wf_ishape: `%`(ishape_2) - -- wf_vextternop__: `%%%`(ishape_2, ishape_1, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_99{ishape_1 : ishape, ishape_2 : ishape, sx : sx}: - `%`(VNARROW_instr(ishape_1, ishape_2, sx)) - -- wf_ishape: `%`(ishape_1) - -- wf_ishape: `%`(ishape_2) - -- if (($lsize($lanetype(ishape_2!`%`_ishape.0)) = (2 * $lsize($lanetype(ishape_1!`%`_ishape.0)))) /\ ((2 * $lsize($lanetype(ishape_1!`%`_ishape.0))) <= 32)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_100{shape_1 : shape, shape_2 : shape, var_0 : vcvtop__}: - `%`(VCVTOP_instr(shape_1, shape_2, var_0)) - -- wf_shape: `%`(shape_1) - -- wf_shape: `%`(shape_2) - -- wf_vcvtop__: `%%%`(shape_2, shape_1, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_101{shape : shape}: - `%`(VSPLAT_instr(shape)) - -- wf_shape: `%`(shape) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_102{shape : shape, `sx?` : sx?, laneidx : laneidx}: - `%`(VEXTRACT_LANE_instr(shape, `sx?`, laneidx)) - -- wf_shape: `%`(shape) - -- wf_uN: `%%`(8, laneidx) - -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_103{shape : shape, laneidx : laneidx}: - `%`(VREPLACE_LANE_instr(shape, laneidx)) - -- wf_shape: `%`(shape) - -- wf_uN: `%%`(8, laneidx) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_104{u31 : u31}: - `%`(`REF.I31_NUM`_instr(u31)) - -- wf_uN: `%%`(31, u31) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_105: - `%`(`REF.NULL_ADDR`_instr) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_106{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_instr(structaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_107{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_instr(arrayaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_108{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_instr(funcaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_109{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_instr(exnaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_110{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_instr(hostaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_111{ref : ref}: - `%`(`REF.EXTERN`_instr(ref)) - -- wf_ref: `%`(ref) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_112{n : n, `instr*` : instr*, `instr*_0` : instr*}: - `%`(`LABEL_%{%}%`_instr(n, `instr*`, `instr*_0`)) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- (wf_instr: `%`(`instr*_0`))*{`instr*_0` <- `instr*_0`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_113{n : n, frame : frame, `instr*` : instr*}: - `%`(`FRAME_%{%}%`_instr(n, frame, `instr*`)) - -- wf_frame: `%`(frame) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_114{n : n, `catch*` : catch*, `instr*` : instr*}: - `%`(`HANDLER_%{%}%`_instr(n, `catch*`, `instr*`)) - -- (wf_catch: `%`(catch))*{catch <- `catch*`} - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_115: - `%`(TRAP_instr) -} - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -syntax expr = instr* - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $memarg0 : memarg - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $const(consttype : consttype, lit_ : lit_) : instr - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_shape(shape : shape) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype?{valtype <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_catch(catch : catch) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{tagidx : uN, labelidx : uN}(CATCH_catch(tagidx, labelidx)) = $free_tagidx(tagidx) +++ $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{tagidx : uN, labelidx : uN}(CATCH_REF_catch(tagidx, labelidx)) = $free_tagidx(tagidx) +++ $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_catch(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.1-584.44 -def $shift_labelidxs(labelidx*) : labelidx* - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:585.1-585.32 - def $shift_labelidxs([]) = [] - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:586.1-586.66 - def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 - def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) -} - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.1-420.30 -def $free_instr(instr : instr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 - def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 - def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 - def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(LOOP_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:442.1-443.79 - def $free_instr{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}(`IF%%ELSE%`_instr(blocktype, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) = $free_blocktype(blocktype) +++ $free_block(instr_1*{instr_1 <- `instr_1*`}) +++ $free_block(instr_2*{instr_2 <- `instr_2*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:445.1-445.56 - def $free_instr{labelidx : uN}(BR_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:446.1-446.59 - def $free_instr{labelidx : uN}(BR_IF_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:447.1-448.69 - def $free_instr{`labelidx*` : labelidx*, labelidx' : uN}(BR_TABLE_instr(labelidx*{labelidx <- `labelidx*`}, labelidx')) = $free_list($free_labelidx(labelidx)*{labelidx <- `labelidx*`}) +++ $free_labelidx(labelidx') - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:449.1-449.64 - def $free_instr{labelidx : uN}(BR_ON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:450.1-450.68 - def $free_instr{labelidx : uN}(BR_ON_NON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:451.1-452.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:453.1-454.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:456.1-456.55 - def $free_instr{funcidx : uN}(CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:457.1-457.59 - def $free_instr{typeuse : typeuse}(CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:458.1-459.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 - def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 - def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 - def $free_instr{typeuse : typeuse}(RETURN_CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:463.1-464.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(RETURN_CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:466.1-466.53 - def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 - def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 - def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 - def $free_instr{numtype : numtype, numlit : num_}(CONST_instr(numtype, numlit)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:472.1-472.60 - def $free_instr{numtype : numtype, unop : unop_}(UNOP_instr(numtype, unop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:473.1-473.62 - def $free_instr{numtype : numtype, binop : binop_}(BINOP_instr(numtype, binop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:474.1-474.64 - def $free_instr{numtype : numtype, testop : testop_}(TESTOP_instr(numtype, testop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:475.1-475.62 - def $free_instr{numtype : numtype, relop : relop_}(RELOP_instr(numtype, relop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:476.1-477.55 - def $free_instr{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}(CVTOP_instr(numtype_1, numtype_2, cvtop)) = $free_numtype(numtype_1) +++ $free_numtype(numtype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:479.1-479.64 - def $free_instr{vectype : vectype, veclit : uN}(VCONST_instr(vectype, veclit)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:480.1-480.64 - def $free_instr{vectype : vectype, vvunop : vvunop}(VVUNOP_instr(vectype, vvunop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:481.1-481.66 - def $free_instr{vectype : vectype, vvbinop : vvbinop}(VVBINOP_instr(vectype, vvbinop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:482.1-482.68 - def $free_instr{vectype : vectype, vvternop : vvternop}(VVTERNOP_instr(vectype, vvternop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:483.1-483.68 - def $free_instr{vectype : vectype, vvtestop : vvtestop}(VVTESTOP_instr(vectype, vvtestop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:484.1-484.56 - def $free_instr{shape : shape, vunop : vunop_}(VUNOP_instr(shape, vunop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:485.1-485.58 - def $free_instr{shape : shape, vbinop : vbinop_}(VBINOP_instr(shape, vbinop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:486.1-486.60 - def $free_instr{shape : shape, vternop : vternop_}(VTERNOP_instr(shape, vternop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:487.1-487.60 - def $free_instr{shape : shape, vtestop : vtestop_}(VTESTOP_instr(shape, vtestop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:488.1-488.58 - def $free_instr{shape : shape, vrelop : vrelop_}(VRELOP_instr(shape, vrelop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:489.1-489.64 - def $free_instr{ishape : ishape, vshiftop : vshiftop_}(VSHIFTOP_instr(ishape, vshiftop)) = $free_shape(ishape!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:490.1-490.55 - def $free_instr{ishape : ishape}(VBITMASK_instr(ishape)) = $free_shape(ishape!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:491.1-491.66 - def $free_instr{bshape : bshape, vswizzlop : vswizzlop_}(VSWIZZLOP_instr(bshape, vswizzlop)) = $free_shape(bshape!`%`_bshape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:492.1-492.64 - def $free_instr{bshape : bshape, `laneidx*` : laneidx*}(VSHUFFLE_instr(bshape, laneidx*{laneidx <- `laneidx*`})) = $free_shape(bshape!`%`_bshape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:493.1-494.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}(VEXTUNOP_instr(ishape_1, ishape_2, vextunop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:495.1-496.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:497.1-498.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:499.1-500.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, sx : sx}(VNARROW_instr(ishape_1, ishape_2, sx)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:501.1-502.47 - def $free_instr{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}(VCVTOP_instr(shape_1, shape_2, vcvtop)) = $free_shape(shape_1) +++ $free_shape(shape_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:503.1-503.51 - def $free_instr{shape : shape}(VSPLAT_instr(shape)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:504.1-504.70 - def $free_instr{shape : shape, `sx?` : sx?, laneidx : uN}(VEXTRACT_LANE_instr(shape, sx?{sx <- `sx?`}, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:505.1-505.66 - def $free_instr{shape : shape, laneidx : uN}(VREPLACE_LANE_instr(shape, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:507.1-507.62 - def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 - def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 - def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 - def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 - def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 - def $free_instr{reftype : reftype}(`REF.CAST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:513.1-513.59 - def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 - def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 - def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 - def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 - def $free_instr{typeidx : uN}(`STRUCT.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:520.1-520.69 - def $free_instr{`sx?` : sx?, typeidx : uN, u32 : uN}(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:521.1-521.65 - def $free_instr{typeidx : uN, u32 : uN}(`STRUCT.SET`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:523.1-523.60 - def $free_instr{typeidx : uN}(`ARRAY.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:524.1-524.68 - def $free_instr{typeidx : uN}(`ARRAY.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:525.1-525.70 - def $free_instr{typeidx : uN, u32 : uN}(`ARRAY.NEW_FIXED`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:526.1-527.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.NEW_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:528.1-529.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:530.1-530.64 - def $free_instr{`sx?` : sx?, typeidx : uN}(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:531.1-531.60 - def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 - def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 - def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 - def $free_instr{typeidx_1 : uN, typeidx_2 : uN}(`ARRAY.COPY`_instr(typeidx_1, typeidx_2)) = $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:536.1-537.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.INIT_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:538.1-539.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 - def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 - def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 - def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 - def $free_instr{localidx : uN}(`LOCAL.SET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:546.1-546.63 - def $free_instr{localidx : uN}(`LOCAL.TEE`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:548.1-548.67 - def $free_instr{globalidx : uN}(`GLOBAL.GET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:549.1-549.67 - def $free_instr{globalidx : uN}(`GLOBAL.SET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:551.1-551.63 - def $free_instr{tableidx : uN}(`TABLE.GET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:552.1-552.63 - def $free_instr{tableidx : uN}(`TABLE.SET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:553.1-553.64 - def $free_instr{tableidx : uN}(`TABLE.SIZE`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:554.1-554.64 - def $free_instr{tableidx : uN}(`TABLE.GROW`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:555.1-555.64 - def $free_instr{tableidx : uN}(`TABLE.FILL`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:556.1-557.59 - def $free_instr{tableidx_1 : uN, tableidx_2 : uN}(`TABLE.COPY`_instr(tableidx_1, tableidx_2)) = $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:558.1-559.53 - def $free_instr{tableidx : uN, elemidx : uN}(`TABLE.INIT`_instr(tableidx, elemidx)) = $free_tableidx(tableidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:560.1-560.60 - def $free_instr{elemidx : uN}(`ELEM.DROP`_instr(elemidx)) = $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:562.1-563.49 - def $free_instr{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}(LOAD_instr(numtype, loadop?{loadop <- `loadop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:564.1-565.49 - def $free_instr{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}(STORE_instr(numtype, storeop?{storeop <- `storeop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:566.1-567.49 - def $free_instr{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}(VLOAD_instr(vectype, vloadop?{vloadop <- `vloadop?`}, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:568.1-569.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:570.1-571.49 - def $free_instr{vectype : vectype, memidx : uN, memarg : memarg}(VSTORE_instr(vectype, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:572.1-573.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:574.1-574.59 - def $free_instr{memidx : uN}(`MEMORY.SIZE`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:575.1-575.59 - def $free_instr{memidx : uN}(`MEMORY.GROW`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:576.1-576.59 - def $free_instr{memidx : uN}(`MEMORY.FILL`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:577.1-578.51 - def $free_instr{memidx_1 : uN, memidx_2 : uN}(`MEMORY.COPY`_instr(memidx_1, memidx_2)) = $free_memidx(memidx_1) +++ $free_memidx(memidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:579.1-580.49 - def $free_instr{memidx : uN, dataidx : uN}(`MEMORY.INIT`_instr(memidx, dataidx)) = $free_memidx(memidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:581.1-581.60 - def $free_instr{dataidx : uN}(`DATA.DROP`_instr(dataidx)) = $free_dataidx(dataidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.1-421.31 -def $free_block(instr*) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:589.1-590.47 - def $free_block{`instr*` : instr*}(instr*{instr <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] - -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) -} - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_expr(expr : expr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax elemmode = - | ACTIVE(tableidx : tableidx, expr : expr) - | PASSIVE - | DECLARE - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_elemmode: `%`(elemmode) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule elemmode_case_0{tableidx : tableidx, expr : expr}: - `%`(ACTIVE_elemmode(tableidx, expr)) - -- wf_uN: `%%`(32, tableidx) - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule elemmode_case_1: - `%`(PASSIVE_elemmode) - - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule elemmode_case_2: - `%`(DECLARE_elemmode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax datamode = - | ACTIVE(memidx : memidx, expr : expr) - | PASSIVE - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_datamode: `%`(datamode) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule datamode_case_0{memidx : memidx, expr : expr}: - `%`(ACTIVE_datamode(memidx, expr)) - -- wf_uN: `%%`(32, memidx) - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule datamode_case_1: - `%`(PASSIVE_datamode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax type = - | TYPE(rectype : rectype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax tag = - | TAG(tagtype : tagtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_tag: `%`(tag) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule tag_case_0{tagtype : tagtype}: - `%`(TAG_tag(tagtype)) - -- wf_typeuse: `%`(tagtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax global = - | GLOBAL(globaltype : globaltype, expr : expr) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_global: `%`(global) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule global_case_0{globaltype : globaltype, expr : expr}: - `%`(GLOBAL_global(globaltype, expr)) - -- wf_globaltype: `%`(globaltype) - -- (wf_instr: `%`(expr))*{expr <- expr} - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax mem = - | MEMORY(memtype : memtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_mem: `%`(mem) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule mem_case_0{memtype : memtype}: - `%`(MEMORY_mem(memtype)) - -- wf_memtype: `%`(memtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax table = - | TABLE(tabletype : tabletype, expr : expr) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_table: `%`(table) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule table_case_0{tabletype : tabletype, expr : expr}: - `%`(TABLE_table(tabletype, expr)) - -- wf_tabletype: `%`(tabletype) - -- (wf_instr: `%`(expr))*{expr <- expr} - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax data = - | DATA(`byte*` : byte*, datamode : datamode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_data: `%`(data) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule data_case_0{`byte*` : byte*, datamode : datamode}: - `%`(DATA_data(`byte*`, datamode)) - -- (wf_byte: `%`(byte))*{byte <- `byte*`} - -- wf_datamode: `%`(datamode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax local = - | LOCAL(valtype : valtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_local: `%`(local) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule local_case_0{valtype : valtype}: - `%`(LOCAL_local(valtype)) - -- wf_valtype: `%`(valtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax func = - | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_func: `%`(func) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule func_case_0{typeidx : typeidx, `local*` : local*, expr : expr}: - `%`(FUNC_func(typeidx, `local*`, expr)) - -- wf_uN: `%%`(32, typeidx) - -- (wf_local: `%`(local))*{local <- `local*`} - -- (wf_instr: `%`(expr))*{expr <- expr} - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax elem = - | ELEM(reftype : reftype, `expr*` : expr*, elemmode : elemmode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_elem: `%`(elem) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule elem_case_0{reftype : reftype, `expr*` : expr*, elemmode : elemmode}: - `%`(ELEM_elem(reftype, `expr*`, elemmode)) - -- wf_reftype: `%`(reftype) - -- (wf_instr: `%`(expr))*{expr <- expr}*{expr <- `expr*`} - -- wf_elemmode: `%`(elemmode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax start = - | START(funcidx : funcidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_start: `%`(start) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule start_case_0{funcidx : funcidx}: - `%`(START_start(funcidx)) - -- wf_uN: `%%`(32, funcidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax import = - | IMPORT(name : name, name : name, externtype : externtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_import: `%`(import) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule import_case_0{name : name, name_0 : name, externtype : externtype}: - `%`(IMPORT_import(name, name_0, externtype)) - -- wf_name: `%`(name) - -- wf_name: `%`(name_0) - -- wf_externtype: `%`(externtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax export = - | EXPORT(name : name, externidx : externidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_export: `%`(export) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule export_case_0{name : name, externidx : externidx}: - `%`(EXPORT_export(name, externidx)) - -- wf_name: `%`(name) - -- wf_externidx: `%`(externidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -syntax module = - | MODULE(list(syntax type), list(syntax import), list(syntax tag), list(syntax global), list(syntax mem), list(syntax table), list(syntax func), list(syntax data), list(syntax elem), `start?` : start?, list(syntax export)) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -relation wf_module: `%`(module) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - rule module_case_0{var_0 : list(syntax type), var_1 : list(syntax import), var_2 : list(syntax tag), var_3 : list(syntax global), var_4 : list(syntax mem), var_5 : list(syntax table), var_6 : list(syntax func), var_7 : list(syntax data), var_8 : list(syntax elem), `start?` : start?, var_9 : list(syntax export)}: - `%`(MODULE_module(var_0, var_1, var_2, var_3, var_4, var_5, var_6, var_7, var_8, `start?`, var_9)) - -- (wf_start: `%`(start))?{start <- `start?`} - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_type(type : type) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_tag(tag : tag) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_global(global : global) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_mem(mem : mem) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_local(local : local) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_func(func : func) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(data : data) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elemmode(elemmode : elemmode) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elem(elem : elem) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_start(start : start) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_export(export : export) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $funcidx_module(module : module) : funcidx* - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $funcidx_module{module : module}(module) = $free_module(module).FUNCS_free - -;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $dataidx_funcs(func*) : dataidx* - ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $dataidx_funcs{`func*` : func*}(func*{func <- `func*`}) = $free_list($free_func(func)*{func <- `func*`}).DATAS_free - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax init = - | SET - | UNSET - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax localtype = - | `%%`(init : init, valtype : valtype) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -relation wf_localtype: `%`(localtype) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - rule localtype_case_0{init : init, valtype : valtype}: - `%`(`%%`_localtype(init, valtype)) - -- wf_valtype: `%`(valtype) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax instrtype = - | `%->_%%`(resulttype : resulttype, `localidx*` : localidx*, resulttype : resulttype) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -relation wf_instrtype: `%`(instrtype) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - rule instrtype_case_0{resulttype : resulttype, `localidx*` : localidx*, resulttype_0 : resulttype}: - `%`(`%->_%%`_instrtype(resulttype, `localidx*`, resulttype_0)) - -- (wf_uN: `%%`(32, localidx))*{localidx <- `localidx*`} - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax context = -{ - TYPES deftype*, - TAGS tagtype*, - GLOBALS globaltype*, - MEMS memtype*, - TABLES tabletype*, - FUNCS deftype*, - DATAS datatype*, - ELEMS elemtype*, - LOCALS localtype*, - LABELS resulttype*, - RETURN resulttype?, - REFS funcidx*, - RECS subtype* -} - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -relation wf_context: `%`(context) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - rule context_case_{var_0 : deftype*, var_1 : tagtype*, var_2 : globaltype*, var_3 : memtype*, var_4 : tabletype*, var_5 : deftype*, var_6 : datatype*, var_7 : elemtype*, var_8 : localtype*, var_9 : resulttype*, var_10 : resulttype?, var_11 : funcidx*, var_12 : subtype*}: - `%`({TYPES var_0, TAGS var_1, GLOBALS var_2, MEMS var_3, TABLES var_4, FUNCS var_5, DATAS var_6, ELEMS var_7, LOCALS var_8, LABELS var_9, RETURN var_10, REFS var_11, RECS var_12}) - -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} - -- (wf_globaltype: `%`(var_2))*{var_2 <- var_2} - -- (wf_memtype: `%`(var_3))*{var_3 <- var_3} - -- (wf_tabletype: `%`(var_4))*{var_4 <- var_4} - -- (wf_reftype: `%`(var_7))*{var_7 <- var_7} - -- (wf_localtype: `%`(var_8))*{var_8 <- var_8} - -- (wf_uN: `%%`(32, var_11))*{var_11 <- var_11} - -- (wf_subtype: `%`(var_12))*{var_12 <- var_12} - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.1-49.158 -def $with_locals(context : context, localidx*, localtype*) : context? - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:51.1-51.34 - def $with_locals{C : context}(C, [], []) = ?(C) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:52.1-52.90 - def $with_locals{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*}(C, [x_1] ++ x*{x <- `x*`}, [lct_1] ++ lct*{lct <- `lct*`}) = $with_locals(C[LOCALS_context[x_1!`%`_uN.0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}) - def $with_locals{x0 : context, x1 : localidx*, x2 : localtype*}(x0, x1, x2) = ?() - -- otherwise -} - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 -def $clos_deftypes(deftype*) : deftype* - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 - def $clos_deftypes([]) = [] - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:72.1-72.101 - def $clos_deftypes{`dt*` : deftype*, dt_n : deftype}(dt*{dt <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, (dt' : deftype <: typeuse)*{dt' <- `dt'*`})] - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(dt*{dt <- `dt*`}) -} - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_valtype(context : context, valtype : valtype) : valtype - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype}(C, dt) = $subst_all_deftype(dt, (dt' : deftype <: typeuse)*{dt' <- `dt'*`}) - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(C.TYPES_context) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse}(C, jt) = $subst_all_tagtype(jt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) - -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Numtype_ok: `%|-%:OK`(context, numtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, numtype : numtype}: - `%|-%:OK`(C, numtype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Vectype_ok: `%|-%:OK`(context, vectype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, vectype : vectype}: - `%|-%:OK`(C, vectype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -syntax oktypenat = - | OK(nat) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Packtype_ok: `%|-%:OK`(context, packtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, packtype : packtype}: - `%|-%:OK`(C, packtype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Packtype_sub: `%|-%<:%`(context, packtype, packtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, packtype : packtype}: - `%|-%<:%`(C, packtype, packtype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Numtype_sub: `%|-%<:%`(context, numtype, numtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, numtype : numtype}: - `%|-%<:%`(C, numtype, numtype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Expand: `%~~%`(deftype, comptype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: - `%~~%`(deftype, comptype) - -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, vectype : vectype}: - `%|-%<:%`(C, vectype, vectype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $before(typeuse : typeuse, nat : nat) : bool - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $before{j : nat, i : nat}(REC_typeuse(j), i) = (j < i) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $before{typeuse : typeuse, i : nat}(typeuse, i) = true - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $unrollht_(context : context, heaptype : heaptype) : subtype - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, deftype : deftype}(C, (deftype : deftype <: heaptype)) = $unrolldt(deftype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, typeidx : uN}(C, _IDX_heaptype(typeidx)) = $unrolldt(C.TYPES_context[typeidx!`%`_uN.0]) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:9.1-9.92 -relation Heaptype_ok: `%|-%:OK`(context, heaptype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:20.1-21.24 - rule abs{C : context, absheaptype : absheaptype}: - `%|-%:OK`(C, (absheaptype : absheaptype <: heaptype)) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:23.1-25.35 - rule typeuse{C : context, typeuse : typeuse}: - `%|-%:OK`(C, (typeuse : typeuse <: heaptype)) - -- Typeuse_ok: `%|-%:OK`(C, typeuse) - -- wf_context: `%`(C) - -- wf_typeuse: `%`(typeuse) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:27.1-28.16 - rule bot{C : context}: - `%|-%:OK`(C, BOT_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(BOT_heaptype) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:10.1-10.91 -relation Reftype_ok: `%|-%:OK`(context, reftype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:30.1-32.37 - rule _{C : context, heaptype : heaptype}: - `%|-%:OK`(C, REF_reftype(?(NULL_null), heaptype)) - -- Heaptype_ok: `%|-%:OK`(C, heaptype) - -- wf_context: `%`(C) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), heaptype)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:11.1-11.91 -relation Valtype_ok: `%|-%:OK`(context, valtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:34.1-36.35 - rule num{C : context, numtype : numtype}: - `%|-%:OK`(C, (numtype : numtype <: valtype)) - -- Numtype_ok: `%|-%:OK`(C, numtype) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:38.1-40.35 - rule vec{C : context, vectype : vectype}: - `%|-%:OK`(C, (vectype : vectype <: valtype)) - -- Vectype_ok: `%|-%:OK`(C, vectype) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:42.1-44.35 - rule ref{C : context, reftype : reftype}: - `%|-%:OK`(C, (reftype : reftype <: valtype)) - -- Reftype_ok: `%|-%:OK`(C, reftype) - -- wf_context: `%`(C) - -- wf_reftype: `%`(reftype) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:46.1-47.16 - rule bot{C : context}: - `%|-%:OK`(C, BOT_valtype) - -- wf_context: `%`(C) - -- wf_valtype: `%`(BOT_valtype) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:12.1-12.94 -relation Typeuse_ok: `%|-%:OK`(context, typeuse) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 - rule typeidx{C : context, typeidx : typeidx, dt : deftype}: - `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if (C.TYPES_context[typeidx!`%`_uN.0] = dt) - -- wf_context: `%`(C) - -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 - rule rec{C : context, i : n, st : subtype}: - `%|-%:OK`(C, REC_typeuse(i)) - -- if (C.RECS_context[i] = st) - -- wf_context: `%`(C) - -- wf_subtype: `%`(st) - -- wf_typeuse: `%`(REC_typeuse(i)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 - rule deftype{C : context, deftype : deftype}: - `%|-%:OK`(C, (deftype : deftype <: typeuse)) - -- Deftype_ok: `%|-%:OK`(C, deftype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:53.1-53.100 -relation Resulttype_ok: `%|-%:OK`(context, resulttype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:60.1-62.32 - rule _{C : context, `t*` : valtype*}: - `%|-%:OK`(C, `%`_resulttype(t*{t <- `t*`})) - -- (Valtype_ok: `%|-%:OK`(C, t))*{t <- `t*`} - -- wf_context: `%`(C) - -- (wf_valtype: `%`(t))*{t <- `t*`} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:92.1-92.104 -relation Fieldtype_ok: `%|-%:OK`(context, fieldtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:130.1-132.43 - rule _{C : context, storagetype : storagetype}: - `%|-%:OK`(C, `%%`_fieldtype(?(MUT_mut), storagetype)) - -- Storagetype_ok: `%|-%:OK`(C, storagetype) - -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), storagetype)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:93.1-93.106 -relation Storagetype_ok: `%|-%:OK`(context, storagetype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:122.1-124.35 - rule val{C : context, valtype : valtype}: - `%|-%:OK`(C, (valtype : valtype <: storagetype)) - -- Valtype_ok: `%|-%:OK`(C, valtype) - -- wf_context: `%`(C) - -- wf_valtype: `%`(valtype) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:126.1-128.37 - rule pack{C : context, packtype : packtype}: - `%|-%:OK`(C, (packtype : packtype <: storagetype)) - -- Packtype_ok: `%|-%:OK`(C, packtype) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:94.1-94.103 -relation Comptype_ok: `%|-%:OK`(context, comptype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:135.1-137.42 - rule struct{C : context, `fieldtype*` : fieldtype*}: - `%|-%:OK`(C, STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) - -- (Fieldtype_ok: `%|-%:OK`(C, fieldtype))*{fieldtype <- `fieldtype*`} - -- wf_context: `%`(C) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:139.1-141.39 - rule array{C : context, fieldtype : fieldtype}: - `%|-%:OK`(C, ARRAY_comptype(fieldtype)) - -- Fieldtype_ok: `%|-%:OK`(C, fieldtype) - -- wf_context: `%`(C) - -- wf_comptype: `%`(ARRAY_comptype(fieldtype)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:143.1-146.35 - rule func{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:OK`(C, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- wf_context: `%`(C) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:97.1-97.126 -relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:167.1-176.49 - rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**}: - `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) - -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) - -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} - -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- (if ($unrollht_(C, (typeuse : typeuse <: heaptype)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} - -- Comptype_ok: `%|-%:OK`(C, comptype) - -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} - -- wf_context: `%`(C) - -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) - -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 -relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:188.1-189.23 - rule empty{C : context, i : nat}: - `%|-%:%`(C, REC_rectype(`%`_list([])), OK_oktypenat(i)) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:191.1-194.49 - rule cons{C : context, subtype_1 : subtype, `subtype*` : subtype*, i : nat}: - `%|-%:%`(C, REC_rectype(`%`_list([subtype_1] ++ subtype*{subtype <- `subtype*`})), OK_oktypenat(i)) - -- Subtype_ok2: `%|-%:%`(C, subtype_1, OK_oktypenat(i)) - -- Rectype_ok2: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypenat((i + 1))) - -- wf_context: `%`(C) - -- wf_subtype: `%`(subtype_1) - -- (wf_subtype: `%`(subtype))*{subtype <- `subtype*`} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:99.1-99.102 -relation Deftype_ok: `%|-%:OK`(context, deftype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:197.1-201.14 - rule _{C : context, rectype : rectype, i : n, n : n, `subtype*` : subtype*}: - `%|-%:OK`(C, _DEF_deftype(rectype, i)) - -- Rectype_ok2: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}} +++ C, rectype, OK_oktypenat(0)) - -- if (rectype = REC_rectype(`%`_list(subtype^n{subtype <- `subtype*`}))) - -- if (i < n) - -- wf_context: `%`(C) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 -relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 - rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: - `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} - -- wf_context: `%`(C) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:185.1-187.38 - rule array{C : context, ft_1 : fieldtype, ft_2 : fieldtype}: - `%|-%<:%`(C, ARRAY_comptype(ft_1), ARRAY_comptype(ft_2)) - -- Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2) - -- wf_context: `%`(C) - -- wf_comptype: `%`(ARRAY_comptype(ft_1)) - -- wf_comptype: `%`(ARRAY_comptype(ft_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:189.1-192.41 - rule func{C : context, `t_11*` : valtype*, `t_12*` : valtype*, `t_21*` : valtype*, `t_22*` : valtype*}: - `%|-%<:%`(C, `FUNC%->%`_comptype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), `%`_resulttype(t_12*{t_12 <- `t_12*`})), `FUNC%->%`_comptype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`}))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) - -- wf_context: `%`(C) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), `%`_resulttype(t_12*{t_12 <- `t_12*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`}))) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:103.1-103.107 -relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:195.1-197.66 - rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:199.1-202.49 - rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: - `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) - -- wf_context: `%`(C) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 -relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:20.1-21.28 - rule refl{C : context, heaptype : heaptype}: - `%|-%<:%`(C, heaptype, heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:23.1-27.48 - rule trans{C : context, heaptype_1 : heaptype, heaptype_2 : heaptype, heaptype' : heaptype}: - `%|-%<:%`(C, heaptype_1, heaptype_2) - -- Heaptype_ok: `%|-%:OK`(C, heaptype') - -- Heaptype_sub: `%|-%<:%`(C, heaptype_1, heaptype') - -- Heaptype_sub: `%|-%<:%`(C, heaptype', heaptype_2) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype_1) - -- wf_heaptype: `%`(heaptype_2) - -- wf_heaptype: `%`(heaptype') - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:29.1-30.17 - rule `eq-any`{C : context}: - `%|-%<:%`(C, EQ_heaptype, ANY_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(EQ_heaptype) - -- wf_heaptype: `%`(ANY_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:32.1-33.17 - rule `i31-eq`{C : context}: - `%|-%<:%`(C, I31_heaptype, EQ_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(I31_heaptype) - -- wf_heaptype: `%`(EQ_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:35.1-36.20 - rule `struct-eq`{C : context}: - `%|-%<:%`(C, STRUCT_heaptype, EQ_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(STRUCT_heaptype) - -- wf_heaptype: `%`(EQ_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:38.1-39.19 - rule `array-eq`{C : context}: - `%|-%<:%`(C, ARRAY_heaptype, EQ_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(ARRAY_heaptype) - -- wf_heaptype: `%`(EQ_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:41.1-43.42 - rule struct{C : context, deftype : deftype, `fieldtype*` : fieldtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), STRUCT_heaptype) - -- Expand: `%~~%`(deftype, STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(STRUCT_heaptype) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:45.1-47.40 - rule array{C : context, deftype : deftype, fieldtype : fieldtype}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), ARRAY_heaptype) - -- Expand: `%~~%`(deftype, ARRAY_comptype(fieldtype)) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(ARRAY_heaptype) - -- wf_comptype: `%`(ARRAY_comptype(fieldtype)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:49.1-51.42 - rule func{C : context, deftype : deftype, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), FUNC_heaptype) - -- Expand: `%~~%`(deftype, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(FUNC_heaptype) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:53.1-55.46 - rule def{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: heaptype), (deftype_2 : deftype <: heaptype)) - -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 - rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: - `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) - -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[typeidx!`%`_uN.0] : deftype <: heaptype), heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 - rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: - `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, (C.TYPES_context[typeidx!`%`_uN.0] : deftype <: heaptype)) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 - rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: - `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) - -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(REC_heaptype(i)) - -- wf_heaptype: `%`(STRUCT_heaptype) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 - rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: - `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(REC_heaptype(i)) - -- wf_heaptype: `%`(ARRAY_heaptype) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 - rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) - -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(REC_heaptype(i)) - -- wf_heaptype: `%`(FUNC_heaptype) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 - rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: - `%|-%<:%`(C, REC_heaptype(i), (typeuse*{typeuse <- `typeuse*`}[j] : typeuse <: heaptype)) - -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(REC_heaptype(i)) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 - rule none{C : context, heaptype : heaptype}: - `%|-%<:%`(C, NONE_heaptype, heaptype) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, ANY_heaptype) - -- if (heaptype =/= BOT_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(NONE_heaptype) - -- wf_heaptype: `%`(ANY_heaptype) - -- wf_heaptype: `%`(BOT_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:86.1-89.25 - rule nofunc{C : context, heaptype : heaptype}: - `%|-%<:%`(C, NOFUNC_heaptype, heaptype) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, FUNC_heaptype) - -- if (heaptype =/= BOT_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(NOFUNC_heaptype) - -- wf_heaptype: `%`(FUNC_heaptype) - -- wf_heaptype: `%`(BOT_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:91.1-94.25 - rule noexn{C : context, heaptype : heaptype}: - `%|-%<:%`(C, NOEXN_heaptype, heaptype) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, EXN_heaptype) - -- if (heaptype =/= BOT_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(NOEXN_heaptype) - -- wf_heaptype: `%`(EXN_heaptype) - -- wf_heaptype: `%`(BOT_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:96.1-99.25 - rule noextern{C : context, heaptype : heaptype}: - `%|-%<:%`(C, NOEXTERN_heaptype, heaptype) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, EXTERN_heaptype) - -- if (heaptype =/= BOT_heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(NOEXTERN_heaptype) - -- wf_heaptype: `%`(EXTERN_heaptype) - -- wf_heaptype: `%`(BOT_heaptype) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:101.1-102.23 - rule bot{C : context, heaptype : heaptype}: - `%|-%<:%`(C, BOT_heaptype, heaptype) - -- wf_context: `%`(C) - -- wf_heaptype: `%`(heaptype) - -- wf_heaptype: `%`(BOT_heaptype) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:10.1-10.103 -relation Reftype_sub: `%|-%<:%`(context, reftype, reftype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:105.1-107.37 - rule nonnull{C : context, ht_1 : heaptype, ht_2 : heaptype}: - `%|-%<:%`(C, REF_reftype(?(), ht_1), REF_reftype(?(), ht_2)) - -- Heaptype_sub: `%|-%<:%`(C, ht_1, ht_2) - -- wf_context: `%`(C) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) - -- wf_reftype: `%`(REF_reftype(?(), ht_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:109.1-111.37 - rule null{C : context, ht_1 : heaptype, ht_2 : heaptype}: - `%|-%<:%`(C, REF_reftype(?(NULL_null), ht_1), REF_reftype(?(NULL_null), ht_2)) - -- Heaptype_sub: `%|-%<:%`(C, ht_1, ht_2) - -- wf_context: `%`(C) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ht_1)) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ht_2)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:11.1-11.103 -relation Valtype_sub: `%|-%<:%`(context, valtype, valtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:114.1-116.46 - rule num{C : context, numtype_1 : numtype, numtype_2 : numtype}: - `%|-%<:%`(C, (numtype_1 : numtype <: valtype), (numtype_2 : numtype <: valtype)) - -- Numtype_sub: `%|-%<:%`(C, numtype_1, numtype_2) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:118.1-120.46 - rule vec{C : context, vectype_1 : vectype, vectype_2 : vectype}: - `%|-%<:%`(C, (vectype_1 : vectype <: valtype), (vectype_2 : vectype <: valtype)) - -- Vectype_sub: `%|-%<:%`(C, vectype_1, vectype_2) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:122.1-124.46 - rule ref{C : context, reftype_1 : reftype, reftype_2 : reftype}: - `%|-%<:%`(C, (reftype_1 : reftype <: valtype), (reftype_2 : reftype <: valtype)) - -- Reftype_sub: `%|-%<:%`(C, reftype_1, reftype_2) - -- wf_context: `%`(C) - -- wf_reftype: `%`(reftype_1) - -- wf_reftype: `%`(reftype_2) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:126.1-127.22 - rule bot{C : context, valtype : valtype}: - `%|-%<:%`(C, BOT_valtype, valtype) - -- wf_context: `%`(C) - -- wf_valtype: `%`(valtype) - -- wf_valtype: `%`(BOT_valtype) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:132.1-132.115 -relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 - rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} - -- wf_context: `%`(C) - -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} - -- (wf_valtype: `%`(t_2))*{t_2 <- `t_2*`} - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:150.1-150.119 -relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:162.1-164.46 - rule val{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, (valtype_1 : valtype <: storagetype), (valtype_2 : valtype <: storagetype)) - -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) - -- wf_context: `%`(C) - -- wf_valtype: `%`(valtype_1) - -- wf_valtype: `%`(valtype_2) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:166.1-168.49 - rule pack{C : context, packtype_1 : packtype, packtype_2 : packtype}: - `%|-%<:%`(C, (packtype_1 : packtype <: storagetype), (packtype_2 : packtype <: storagetype)) - -- Packtype_sub: `%|-%<:%`(C, packtype_1, packtype_2) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:151.1-151.117 -relation Fieldtype_sub: `%|-%<:%`(context, fieldtype, fieldtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:171.1-173.40 - rule const{C : context, zt_1 : storagetype, zt_2 : storagetype}: - `%|-%<:%`(C, `%%`_fieldtype(?(), zt_1), `%%`_fieldtype(?(), zt_2)) - -- Storagetype_sub: `%|-%<:%`(C, zt_1, zt_2) - -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_1)) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:175.1-178.40 - rule var{C : context, zt_1 : storagetype, zt_2 : storagetype}: - `%|-%<:%`(C, `%%`_fieldtype(?(MUT_mut), zt_1), `%%`_fieldtype(?(MUT_mut), zt_2)) - -- Storagetype_sub: `%|-%<:%`(C, zt_1, zt_2) - -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) - -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_1)) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_2)) -} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Localtype_ok: `%|-%:OK`(context, localtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, init : init, t : valtype}: - `%|-%:OK`(C, `%%`_localtype(init, t)) - -- Valtype_ok: `%|-%:OK`(C, t) - -- wf_context: `%`(C) - -- wf_localtype: `%`(`%%`_localtype(init, t)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Instrtype_ok: `%|-%:OK`(context, instrtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, `t_1*` : valtype*, `x*` : idx*, `t_2*` : valtype*, `lct*` : localtype*}: - `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- (if (C.LOCALS_context[x!`%`_uN.0] = lct))*{lct <- `lct*`, x <- `x*`} - -- wf_context: `%`(C) - -- (wf_localtype: `%`(lct))*{lct <- `lct*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Expand_use: `%~~_%%`(typeuse, context, comptype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule deftype{deftype : deftype, C : context, comptype : comptype}: - `%~~_%%`((deftype : deftype <: typeuse), C, comptype) - -- Expand: `%~~%`(deftype, comptype) - -- wf_context: `%`(C) - -- wf_comptype: `%`(comptype) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: - `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- Expand: `%~~%`(C.TYPES_context[typeidx!`%`_uN.0], comptype) - -- wf_context: `%`(C) - -- wf_comptype: `%`(comptype) - -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -syntax oktypeidx = - | OK(typeidx : typeidx) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation wf_oktypeidx: `%`(oktypeidx) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule oktypeidx_case_0{typeidx : typeidx}: - `%`(OK_oktypeidx(typeidx)) - -- wf_uN: `%%`(32, typeidx) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**}: - `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) - -- if (|x*{x <- `x*`}| <= 1) - -- (if (x!`%`_uN.0 < x_0!`%`_uN.0))*{x <- `x*`} - -- (if ($unrolldt(C.TYPES_context[x!`%`_uN.0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} - -- Comptype_ok: `%|-%:OK`(C, comptype) - -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} - -- wf_context: `%`(C) - -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) - -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) - -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:96.1-96.126 -relation Rectype_ok: `%|-%:%`(context, rectype, oktypeidx) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:179.1-180.23 - rule empty{C : context, x : idx}: - `%|-%:%`(C, REC_rectype(`%`_list([])), OK_oktypeidx(x)) - -- wf_context: `%`(C) - -- wf_oktypeidx: `%`(OK_oktypeidx(x)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:182.1-185.48 - rule cons{C : context, subtype_1 : subtype, `subtype*` : subtype*, x : idx}: - `%|-%:%`(C, REC_rectype(`%`_list([subtype_1] ++ subtype*{subtype <- `subtype*`})), OK_oktypeidx(x)) - -- Subtype_ok: `%|-%:%`(C, subtype_1, OK_oktypeidx(x)) - -- Rectype_ok: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypeidx(`%`_typeidx((x!`%`_uN.0 + 1)))) - -- wf_context: `%`(C) - -- wf_subtype: `%`(subtype_1) - -- (wf_subtype: `%`(subtype))*{subtype <- `subtype*`} - -- wf_oktypeidx: `%`(OK_oktypeidx(x)) - -- wf_oktypeidx: `%`(OK_oktypeidx(`%`_typeidx((x!`%`_uN.0 + 1)))) -} - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Limits_ok: `%|-%:%`(context, limits, nat) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, n : n, `m?` : m?, k : nat}: - `%|-%:%`(C, `[%..%]`_limits(`%`_u64(n), `%`_u64(m)?{m <- `m?`}), k) - -- if (n <= k) - -- (if ((n <= m) /\ (m <= k)))?{m <- `m?`} - -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n), `%`_u64(m)?{m <- `m?`})) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Tagtype_ok: `%|-%:OK`(context, tagtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, typeuse : typeuse, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:OK`(C, typeuse) - -- Typeuse_ok: `%|-%:OK`(C, typeuse) - -- Expand_use: `%~~_%%`(typeuse, C, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_typeuse: `%`(typeuse) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Globaltype_ok: `%|-%:OK`(context, globaltype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, t : valtype}: - `%|-%:OK`(C, `%%`_globaltype(?(MUT_mut), t)) - -- Valtype_ok: `%|-%:OK`(C, t) - -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Memtype_ok: `%|-%:OK`(context, memtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, addrtype : addrtype, limits : limits}: - `%|-%:OK`(C, `%%PAGE`_memtype(addrtype, limits)) - -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size((addrtype : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_context: `%`(C) - -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Tabletype_ok: `%|-%:OK`(context, tabletype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, addrtype : addrtype, limits : limits, reftype : reftype}: - `%|-%:OK`(C, `%%%`_tabletype(addrtype, limits, reftype)) - -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size((addrtype : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) - -- Reftype_ok: `%|-%:OK`(C, reftype) - -- wf_context: `%`(C) - -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits, reftype)) - -;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -relation Externtype_ok: `%|-%:OK`(context, externtype) - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule tag{C : context, tagtype : tagtype}: - `%|-%:OK`(C, TAG_externtype(tagtype)) - -- Tagtype_ok: `%|-%:OK`(C, tagtype) - -- wf_context: `%`(C) - -- wf_externtype: `%`(TAG_externtype(tagtype)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule global{C : context, globaltype : globaltype}: - `%|-%:OK`(C, GLOBAL_externtype(globaltype)) - -- Globaltype_ok: `%|-%:OK`(C, globaltype) - -- wf_context: `%`(C) - -- wf_externtype: `%`(GLOBAL_externtype(globaltype)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule mem{C : context, memtype : memtype}: - `%|-%:OK`(C, MEM_externtype(memtype)) - -- Memtype_ok: `%|-%:OK`(C, memtype) - -- wf_context: `%`(C) - -- wf_externtype: `%`(MEM_externtype(memtype)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule table{C : context, tabletype : tabletype}: - `%|-%:OK`(C, TABLE_externtype(tabletype)) - -- Tabletype_ok: `%|-%:OK`(C, tabletype) - -- wf_context: `%`(C) - -- wf_externtype: `%`(TABLE_externtype(tabletype)) - - ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule func{C : context, typeuse : typeuse, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:OK`(C, FUNC_externtype(typeuse)) - -- Typeuse_ok: `%|-%:OK`(C, typeuse) - -- Expand_use: `%~~_%%`(typeuse, C, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_externtype: `%`(FUNC_externtype(typeuse)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, `t_11*` : valtype*, `x_1*` : idx*, `t_12*` : valtype*, `t_21*` : valtype*, `x_2*` : idx*, `t_22*` : valtype*, `x*` : idx*, `t*` : valtype*}: - `%|-%<:%`(C, `%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`})), `%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) - -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) - -- (if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} - -- wf_context: `%`(C) - -- (wf_uN: `%%`(32, x))*{x <- `x*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Limits_sub: `%|-%<:%`(context, limits, limits) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule max{C : context, n_1 : n, m_1 : m, n_2 : n, `m_2?` : m?}: - `%|-%<:%`(C, `[%..%]`_limits(`%`_u64(n_1), ?(`%`_u64(m_1))), `[%..%]`_limits(`%`_u64(n_2), `%`_u64(m_2)?{m_2 <- `m_2?`})) - -- if (n_1 >= n_2) - -- (if (m_1 <= m_2))?{m_2 <- `m_2?`} - -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_1), ?(`%`_u64(m_1)))) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_2), `%`_u64(m_2)?{m_2 <- `m_2?`})) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule eps{C : context, n_1 : n, n_2 : n}: - `%|-%<:%`(C, `[%..%]`_limits(`%`_u64(n_1), ?()), `[%..%]`_limits(`%`_u64(n_2), ?())) - -- if (n_1 >= n_2) - -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_1), ?())) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_2), ?())) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Tagtype_sub: `%|-%<:%`(context, tagtype, tagtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: typeuse), (deftype_2 : deftype <: typeuse)) - -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) - -- Deftype_sub: `%|-%<:%`(C, deftype_2, deftype_1) - -- wf_context: `%`(C) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Globaltype_sub: `%|-%<:%`(context, globaltype, globaltype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule const{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, `%%`_globaltype(?(), valtype_1), `%%`_globaltype(?(), valtype_2)) - -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) - -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_1)) - -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule var{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, `%%`_globaltype(?(MUT_mut), valtype_1), `%%`_globaltype(?(MUT_mut), valtype_2)) - -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) - -- Valtype_sub: `%|-%<:%`(C, valtype_2, valtype_1) - -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_1)) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_2)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Memtype_sub: `%|-%<:%`(context, memtype, memtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, addrtype : addrtype, limits_1 : limits, limits_2 : limits}: - `%|-%<:%`(C, `%%PAGE`_memtype(addrtype, limits_1), `%%PAGE`_memtype(addrtype, limits_2)) - -- Limits_sub: `%|-%<:%`(C, limits_1, limits_2) - -- wf_context: `%`(C) - -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits_1)) - -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits_2)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Tabletype_sub: `%|-%<:%`(context, tabletype, tabletype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule _{C : context, addrtype : addrtype, limits_1 : limits, reftype_1 : reftype, limits_2 : limits, reftype_2 : reftype}: - `%|-%<:%`(C, `%%%`_tabletype(addrtype, limits_1, reftype_1), `%%%`_tabletype(addrtype, limits_2, reftype_2)) - -- Limits_sub: `%|-%<:%`(C, limits_1, limits_2) - -- Reftype_sub: `%|-%<:%`(C, reftype_1, reftype_2) - -- Reftype_sub: `%|-%<:%`(C, reftype_2, reftype_1) - -- wf_context: `%`(C) - -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits_1, reftype_1)) - -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits_2, reftype_2)) - -;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec -relation Externtype_sub: `%|-%<:%`(context, externtype, externtype) - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule tag{C : context, tagtype_1 : tagtype, tagtype_2 : tagtype}: - `%|-%<:%`(C, TAG_externtype(tagtype_1), TAG_externtype(tagtype_2)) - -- Tagtype_sub: `%|-%<:%`(C, tagtype_1, tagtype_2) - -- wf_context: `%`(C) - -- wf_externtype: `%`(TAG_externtype(tagtype_1)) - -- wf_externtype: `%`(TAG_externtype(tagtype_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule global{C : context, globaltype_1 : globaltype, globaltype_2 : globaltype}: - `%|-%<:%`(C, GLOBAL_externtype(globaltype_1), GLOBAL_externtype(globaltype_2)) - -- Globaltype_sub: `%|-%<:%`(C, globaltype_1, globaltype_2) - -- wf_context: `%`(C) - -- wf_externtype: `%`(GLOBAL_externtype(globaltype_1)) - -- wf_externtype: `%`(GLOBAL_externtype(globaltype_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule mem{C : context, memtype_1 : memtype, memtype_2 : memtype}: - `%|-%<:%`(C, MEM_externtype(memtype_1), MEM_externtype(memtype_2)) - -- Memtype_sub: `%|-%<:%`(C, memtype_1, memtype_2) - -- wf_context: `%`(C) - -- wf_externtype: `%`(MEM_externtype(memtype_1)) - -- wf_externtype: `%`(MEM_externtype(memtype_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule table{C : context, tabletype_1 : tabletype, tabletype_2 : tabletype}: - `%|-%<:%`(C, TABLE_externtype(tabletype_1), TABLE_externtype(tabletype_2)) - -- Tabletype_sub: `%|-%<:%`(C, tabletype_1, tabletype_2) - -- wf_context: `%`(C) - -- wf_externtype: `%`(TABLE_externtype(tabletype_1)) - -- wf_externtype: `%`(TABLE_externtype(tabletype_2)) - - ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec - rule func{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, FUNC_externtype((deftype_1 : deftype <: typeuse)), FUNC_externtype((deftype_2 : deftype <: typeuse))) - -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) - -- wf_context: `%`(C) - -- wf_externtype: `%`(FUNC_externtype((deftype_1 : deftype <: typeuse))) - -- wf_externtype: `%`(FUNC_externtype((deftype_2 : deftype <: typeuse))) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule valtype{C : context, `valtype?` : valtype?}: - `%|-%:%`(C, _RESULT_blocktype(valtype?{valtype <- `valtype?`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(valtype?{valtype <- `valtype?`})))) - -- (Valtype_ok: `%|-%:OK`(C, valtype))?{valtype <- `valtype?`} - -- wf_context: `%`(C) - -- wf_blocktype: `%`(_RESULT_blocktype(valtype?{valtype <- `valtype?`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(valtype?{valtype <- `valtype?`})))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.TYPES_context[typeidx!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Catch_ok: `%|-%:OK`(context, catch) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: - `%|-%:OK`(C, CATCH_catch(x, l)) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l!`%`_uN.0]) - -- wf_context: `%`(C) - -- wf_catch: `%`(CATCH_catch(x, l)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: - `%|-%:OK`(C, CATCH_REF_catch(x, l)) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[l!`%`_uN.0]) - -- wf_context: `%`(C) - -- wf_catch: `%`(CATCH_REF_catch(x, l)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_all{C : context, l : labelidx}: - `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[l!`%`_uN.0]) - -- wf_context: `%`(C) - -- wf_catch: `%`(CATCH_ALL_catch(l)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_all_ref{C : context, l : labelidx}: - `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[l!`%`_uN.0]) - -- wf_context: `%`(C) - -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -def $default_(valtype : valtype) : val?? - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(?(VCONST_val(Vnn, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) - def $default_{x0 : valtype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Defaultable: `|-%DEFAULTABLE`(valtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule _{t : valtype}: - `|-%DEFAULTABLE`(t) - -- if (!($default_(t)) =/= ?()) - -- wf_valtype: `%`(t) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule _{n : n, m : m, at : addrtype, N : N}: - `|-%:%->%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}, at, N) - -- if (((2 ^ n) : nat <:> rat) <= ((N : nat <:> rat) / (8 : nat <:> rat))) - -- if (m < (2 ^ $size((at : addrtype <: numtype)))) - -- wf_memarg: `%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -def $is_packtype(storagetype : storagetype) : bool - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= ($unpack(zt) : valtype <: storagetype)) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:5.1-5.95 -relation Instr_ok: `%|-%:%`(context, instr, instrtype) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:18.1-19.24 - rule nop{C : context}: - `%|-%:%`(C, NOP_instr, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(NOP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:21.1-23.42 - rule unreachable{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, UNREACHABLE_instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(UNREACHABLE_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:25.1-27.29 - rule drop{C : context, t : valtype}: - `%|-%:%`(C, DROP_instr, `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- Valtype_ok: `%|-%:OK`(C, t) - -- wf_context: `%`(C) - -- wf_instr: `%`(DROP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:29.1-31.29 - rule `select-expl`{C : context, t : valtype}: - `%|-%:%`(C, SELECT_instr(?([t])), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) - -- Valtype_ok: `%|-%:OK`(C, t) - -- wf_context: `%`(C) - -- wf_instr: `%`(SELECT_instr(?([t]))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:33.1-37.37 - rule `select-impl`{C : context, t : valtype, t' : valtype, numtype : numtype, vectype : vectype}: - `%|-%:%`(C, SELECT_instr(?()), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) - -- Valtype_ok: `%|-%:OK`(C, t) - -- Valtype_sub: `%|-%<:%`(C, t, t') - -- if ((t' = (numtype : numtype <: valtype)) \/ (t' = (vectype : vectype <: valtype))) - -- wf_context: `%`(C) - -- wf_valtype: `%`(t') - -- wf_instr: `%`(SELECT_instr(?())) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:53.1-56.67 - rule block{C : context, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: - `%|-%:%`(C, BLOCK_instr(bt, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []} +++ C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BLOCK_instr(bt, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:58.1-61.67 - rule loop{C : context, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: - `%|-%:%`(C, LOOP_instr(bt, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_1*{t_1 <- `t_1*`})], RETURN ?(), REFS [], RECS []} +++ C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(LOOP_instr(bt, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_1*{t_1 <- `t_1*`})], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:63.1-67.71 - rule if{C : context, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x_1*` : idx*, `x_2*` : idx*}: - `%|-%:%`(C, `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`}), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []} +++ C, instr_1*{instr_1 <- `instr_1*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []} +++ C, instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 - rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BR_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 - rule br_if{C : context, l : labelidx, `t*` : valtype*}: - `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) - -- wf_context: `%`(C) - -- wf_instr: `%`(BR_IF_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 - rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l!`%`_uN.0]))*{l <- `l*`} - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l'!`%`_uN.0]) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 - rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: - `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) - -- Heaptype_ok: `%|-%:OK`(C, ht) - -- wf_context: `%`(C) - -- wf_instr: `%`(BR_ON_NULL_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 - rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: - `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) - -- wf_context: `%`(C) - -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 - rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) - -- Reftype_ok: `%|-%:OK`(C, rt_1) - -- Reftype_ok: `%|-%:OK`(C, rt_2) - -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- Reftype_sub: `%|-%<:%`(C, rt_2, rt) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 - rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) - -- Reftype_ok: `%|-%:OK`(C, rt_1) - -- Reftype_ok: `%|-%:OK`(C, rt_2) - -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 - rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(CALL_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 - rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 - rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: - `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- Expand: `%~~%`(C.TYPES_context[y!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:129.1-132.42 - rule return{C : context, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, RETURN_instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.RETURN_context = ?(`%`_resulttype(t*{t <- `t*`}))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(RETURN_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 - rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: - `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_context: `%`(C) - -- (wf_valtype: `%`(t'_2))*{t'_2 <- `t'_2*`} - -- wf_instr: `%`(RETURN_CALL_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 - rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: - `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_context: `%`(C) - -- (wf_valtype: `%`(t'_2))*{t'_2 <- `t'_2*`} - -- wf_instr: `%`(RETURN_CALL_REF_instr(_IDX_typeuse(x))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 - rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: - `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- Expand: `%~~%`(C.TYPES_context[y!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_context: `%`(C) - -- (wf_valtype: `%`(t'_2))*{t'_2 <- `t'_2*`} - -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 - rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(THROW_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 - rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, THROW_REF_instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(THROW_REF_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:175.1-179.34 - rule try_table{C : context, bt : blocktype, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: - `%|-%:%`(C, TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []} +++ C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Catch_ok: `%|-%:OK`(C, catch))*{catch <- `catch*`} - -- wf_context: `%`(C) - -- wf_instr: `%`(TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:202.1-204.31 - rule `ref.null`{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.NULL`_instr(ht), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(NULL_null), ht)]))) - -- Heaptype_ok: `%|-%:OK`(C, ht) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.NULL`_instr(ht)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(NULL_null), ht)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 - rule `ref.func`{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) - -- if (C.FUNCS_context[x!`%`_uN.0] = dt) - -- if (x <- C.REFS_context) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.FUNC`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 - rule `ref.i31`{C : context}: - `%|-%:%`(C, `REF.I31`_instr, `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), I31_heaptype)]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.I31`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), I31_heaptype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:214.1-216.31 - rule `ref.is_null`{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.IS_NULL`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([I32_valtype]))) - -- Heaptype_ok: `%|-%:OK`(C, ht) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:218.1-220.31 - rule `ref.as_non_null`{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.AS_NON_NULL`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([REF_valtype(?(), ht)]))) - -- Heaptype_ok: `%|-%:OK`(C, ht) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([REF_valtype(?(), ht)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:222.1-223.51 - rule `ref.eq`{C : context}: - `%|-%:%`(C, `REF.EQ`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:225.1-229.33 - rule `ref.test`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - -- Reftype_ok: `%|-%:OK`(C, rt) - -- Reftype_ok: `%|-%:OK`(C, rt') - -- Reftype_sub: `%|-%<:%`(C, rt, rt') - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.TEST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:231.1-235.33 - rule `ref.cast`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- Reftype_ok: `%|-%:OK`(C, rt) - -- Reftype_ok: `%|-%:OK`(C, rt') - -- Reftype_sub: `%|-%<:%`(C, rt, rt') - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.CAST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:240.1-241.42 - rule `i31.get`{C : context, sx : sx}: - `%|-%:%`(C, `I31.GET`_instr(sx), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`I31.GET`_instr(sx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 - rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 - rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: - `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 - rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: - `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (ft*{ft <- `ft*`}[i!`%`_uN.0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) - -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 - rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: - `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (ft*{ft <- `ft*`}[i!`%`_uN.0] = `%%`_fieldtype(?(MUT_mut), zt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 - rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: - `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 - rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: - `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 - rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: - `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 - rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: - `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) - -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[y!`%`_uN.0], rt) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 - rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: - `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 - rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: - `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 - rule `array.set`{C : context, x : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 - rule `array.len`{C : context}: - `%|-%:%`(C, `ARRAY.LEN`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.LEN`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 - rule `array.fill`{C : context, x : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 - rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: - `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x_1!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- Expand: `%~~%`(C.TYPES_context[x_2!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 - rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- Storagetype_sub: `%|-%<:%`(C, (C.ELEMS_context[y!`%`_uN.0] : reftype <: storagetype), zt) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 - rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: - `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:332.1-334.26 - rule `extern.convert_any`{C : context, `null_1?` : null?, `null_2?` : null?}: - `%|-%:%`(C, `EXTERN.CONVERT_ANY`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1?{null_1 <- `null_1?`}, ANY_heaptype)]), [], `%`_resulttype([REF_valtype(null_2?{null_2 <- `null_2?`}, EXTERN_heaptype)]))) - -- if (null_1?{null_1 <- `null_1?`} = null_2?{null_2 <- `null_2?`}) - -- wf_context: `%`(C) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1?{null_1 <- `null_1?`}, ANY_heaptype)]), [], `%`_resulttype([REF_valtype(null_2?{null_2 <- `null_2?`}, EXTERN_heaptype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:336.1-338.26 - rule `any.convert_extern`{C : context, `null_1?` : null?, `null_2?` : null?}: - `%|-%:%`(C, `ANY.CONVERT_EXTERN`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1?{null_1 <- `null_1?`}, EXTERN_heaptype)]), [], `%`_resulttype([REF_valtype(null_2?{null_2 <- `null_2?`}, ANY_heaptype)]))) - -- if (null_1?{null_1 <- `null_1?`} = null_2?{null_2 <- `null_2?`}) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1?{null_1 <- `null_1?`}, EXTERN_heaptype)]), [], `%`_resulttype([REF_valtype(null_2?{null_2 <- `null_2?`}, ANY_heaptype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 - rule `local.get`{C : context, x : idx, t : valtype}: - `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 - rule `local.set`{C : context, x : idx, t : valtype, init : init}: - `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(init, t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- wf_localtype: `%`(`%%`_localtype(init, t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 - rule `local.tee`{C : context, x : idx, t : valtype, init : init}: - `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(init, t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- wf_localtype: `%`(`%%`_localtype(init, t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 - rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: - `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 - rule `global.set`{C : context, x : idx, t : valtype}: - `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(MUT_mut), t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 - rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 - rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 - rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: - `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 - rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: - `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 - rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 - rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x_1!`%`_uN.0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if (C.TABLES_context[x_2!`%`_uN.0] = `%%%`_tabletype(at_2, lim_2, rt_2)) - -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at_1, lim_1, rt_1)) - -- wf_tabletype: `%`(`%%%`_tabletype(at_2, lim_2, rt_2)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 - rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt_1)) - -- if (C.ELEMS_context[y!`%`_uN.0] = rt_2) - -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt_2) - -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt_1)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 - rule `elem.drop`{C : context, x : idx, rt : reftype}: - `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if (C.ELEMS_context[x!`%`_uN.0] = rt) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 - rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 - rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 - rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 - rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: - `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x_1!`%`_uN.0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if (C.MEMS_context[x_2!`%`_uN.0] = `%%PAGE`_memtype(at_2, lim_2)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at_1, lim_1)) - -- wf_memtype: `%`(`%%PAGE`_memtype(at_2, lim_2)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 - rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) - -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 - rule `data.drop`{C : context, x : idx}: - `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if (C.DATAS_context[x!`%`_uN.0] = OK_datatype) - -- wf_context: `%`(C) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 - rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 - rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, M) - -- wf_context: `%`(C) - -- wf_instr: `%`(LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 - rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 - rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, M) - -- wf_context: `%`(C) - -- wf_instr: `%`(STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 - rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) - -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 - rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) - -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 - rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 - rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 - rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- if ((i!`%`_uN.0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 - rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) - -- wf_context: `%`(C) - -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 - rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- if ((i!`%`_uN.0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:520.1-521.33 - rule const{C : context, nt : numtype, c_nt : num_}: - `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(CONST_instr(nt, c_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:523.1-524.34 - rule unop{C : context, nt : numtype, unop_nt : unop_}: - `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(UNOP_instr(nt, unop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:526.1-527.39 - rule binop{C : context, nt : numtype, binop_nt : binop_}: - `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BINOP_instr(nt, binop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:529.1-530.39 - rule testop{C : context, nt : numtype, testop_nt : testop_}: - `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(TESTOP_instr(nt, testop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:532.1-533.40 - rule relop{C : context, nt : numtype, relop_nt : relop_}: - `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(RELOP_instr(nt, relop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:535.1-536.44 - rule cvtop{C : context, nt_1 : numtype, nt_2 : numtype, cvtop : cvtop__}: - `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(CVTOP_instr(nt_1, nt_2, cvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:541.1-542.35 - rule vconst{C : context, c : vec_}: - `%|-%:%`(C, VCONST_instr(V128_vectype, c), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:544.1-545.41 - rule vvunop{C : context, vvunop : vvunop}: - `%|-%:%`(C, VVUNOP_instr(V128_vectype, vvunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:547.1-548.48 - rule vvbinop{C : context, vvbinop : vvbinop}: - `%|-%:%`(C, VVBINOP_instr(V128_vectype, vvbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:550.1-551.55 - rule vvternop{C : context, vvternop : vvternop}: - `%|-%:%`(C, VVTERNOP_instr(V128_vectype, vvternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, vvternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:553.1-554.44 - rule vvtestop{C : context, vvtestop : vvtestop}: - `%|-%:%`(C, VVTESTOP_instr(V128_vectype, vvtestop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, vvtestop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:556.1-557.37 - rule vunop{C : context, sh : shape, vunop : vunop_}: - `%|-%:%`(C, VUNOP_instr(sh, vunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VUNOP_instr(sh, vunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:559.1-560.44 - rule vbinop{C : context, sh : shape, vbinop : vbinop_}: - `%|-%:%`(C, VBINOP_instr(sh, vbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:562.1-563.51 - rule vternop{C : context, sh : shape, vternop : vternop_}: - `%|-%:%`(C, VTERNOP_instr(sh, vternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:565.1-566.40 - rule vtestop{C : context, sh : shape, vtestop : vtestop_}: - `%|-%:%`(C, VTESTOP_instr(sh, vtestop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VTESTOP_instr(sh, vtestop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:568.1-569.44 - rule vrelop{C : context, sh : shape, vrelop : vrelop_}: - `%|-%:%`(C, VRELOP_instr(sh, vrelop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:571.1-572.47 - rule vshiftop{C : context, sh : ishape, vshiftop : vshiftop_}: - `%|-%:%`(C, VSHIFTOP_instr(sh, vshiftop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype I32_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype I32_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:574.1-575.33 - rule vbitmask{C : context, sh : ishape}: - `%|-%:%`(C, VBITMASK_instr(sh), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VBITMASK_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:577.1-578.50 - rule vswizzlop{C : context, sh : bshape, vswizzlop : vswizzlop_}: - `%|-%:%`(C, VSWIZZLOP_instr(sh, vswizzlop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VSWIZZLOP_instr(sh, vswizzlop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:580.1-582.29 - rule vshuffle{C : context, sh : bshape, `i*` : laneidx*}: - `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- (if (i!`%`_uN.0 < (2 * $dim(sh!`%`_bshape.0)!`%`_dim.0)))*{i <- `i*`} - -- wf_context: `%`(C) - -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 - rule vsplat{C : context, sh : shape}: - `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VSPLAT_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:587.1-589.21 - rule vextract_lane{C : context, sh : shape, `sx?` : sx?, i : laneidx}: - `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) - -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) - -- wf_context: `%`(C) - -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 - rule vreplace_lane{C : context, sh : shape, i : laneidx}: - `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) - -- wf_context: `%`(C) - -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:595.1-596.50 - rule vextunop{C : context, sh_1 : ishape, sh_2 : ishape, vextunop : vextunop__}: - `%|-%:%`(C, VEXTUNOP_instr(sh_1, sh_2, vextunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VEXTUNOP_instr(sh_1, sh_2, vextunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:598.1-599.57 - rule vextbinop{C : context, sh_1 : ishape, sh_2 : ishape, vextbinop : vextbinop__}: - `%|-%:%`(C, VEXTBINOP_instr(sh_1, sh_2, vextbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VEXTBINOP_instr(sh_1, sh_2, vextbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:601.1-602.64 - rule vextternop{C : context, sh_1 : ishape, sh_2 : ishape, vextternop : vextternop__}: - `%|-%:%`(C, VEXTTERNOP_instr(sh_1, sh_2, vextternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VEXTTERNOP_instr(sh_1, sh_2, vextternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:604.1-605.48 - rule vnarrow{C : context, sh_1 : ishape, sh_2 : ishape, sx : sx}: - `%|-%:%`(C, VNARROW_instr(sh_1, sh_2, sx), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VNARROW_instr(sh_1, sh_2, sx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:607.1-608.46 - rule vcvtop{C : context, sh_1 : shape, sh_2 : shape, vcvtop : vcvtop__}: - `%|-%:%`(C, VCVTOP_instr(sh_1, sh_2, vcvtop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(VCVTOP_instr(sh_1, sh_2, vcvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:6.1-6.96 -relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:613.1-614.24 - rule empty{C : context}: - `%|-%:%`(C, [], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- wf_context: `%`(C) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:617.1-621.82 - rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: - `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if (C.LOCALS_context[x_1!`%`_uN.0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(instr_1) - -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 - rule sub{C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: - `%|-%:%`(C, instr*{instr <- `instr*`}, it') - -- Instrs_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, it) - -- Instrtype_sub: `%|-%<:%`(C, it, it') - -- Instrtype_ok: `%|-%:OK`(C, it') - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(it') - -- wf_instrtype: `%`(it) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:630.1-633.33 - rule frame{C : context, `instr*` : instr*, `t*` : valtype*, `t_1*` : valtype*, `x*` : idx*, `t_2*` : valtype*}: - `%|-%:%`(C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`} ++ t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t*{t <- `t*`})) - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`} ++ t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -} - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Expr_ok: `%|-%:%`(context, expr, resulttype) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule _{C : context, `instr*` : instr*, `t*` : valtype*}: - `%|-%:%`(C, instr*{instr <- `instr*`}, `%`_resulttype(t*{t <- `t*`})) - -- Instrs_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule _{t : valtype}: - `|-%NONDEFAULTABLE`(t) - -- if (!($default_(t)) = ?()) - -- wf_valtype: `%`(t) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Instr_const: `%|-%CONST`(context, instr) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule const{C : context, nt : numtype, c_nt : num_}: - `%|-%CONST`(C, CONST_instr(nt, c_nt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(CONST_instr(nt, c_nt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule vconst{C : context, vt : vectype, c_vt : vec_}: - `%|-%CONST`(C, VCONST_instr(vt, c_vt)) - -- wf_context: `%`(C) - -- wf_instr: `%`(VCONST_instr(vt, c_vt)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `ref.null`{C : context, ht : heaptype}: - `%|-%CONST`(C, `REF.NULL`_instr(ht)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.NULL`_instr(ht)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `ref.i31`{C : context}: - `%|-%CONST`(C, `REF.I31`_instr) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.I31`_instr) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `ref.func`{C : context, x : idx}: - `%|-%CONST`(C, `REF.FUNC`_instr(x)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.FUNC`_instr(x)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `struct.new`{C : context, x : idx}: - `%|-%CONST`(C, `STRUCT.NEW`_instr(x)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `struct.new_default`{C : context, x : idx}: - `%|-%CONST`(C, `STRUCT.NEW_DEFAULT`_instr(x)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `array.new`{C : context, x : idx}: - `%|-%CONST`(C, `ARRAY.NEW`_instr(x)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `array.new_default`{C : context, x : idx}: - `%|-%CONST`(C, `ARRAY.NEW_DEFAULT`_instr(x)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `array.new_fixed`{C : context, x : idx, n : n}: - `%|-%CONST`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `any.convert_extern`{C : context}: - `%|-%CONST`(C, `ANY.CONVERT_EXTERN`_instr) - -- wf_context: `%`(C) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `extern.convert_any`{C : context}: - `%|-%CONST`(C, `EXTERN.CONVERT_ANY`_instr) - -- wf_context: `%`(C) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule `global.get`{C : context, x : idx, t : valtype}: - `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(), t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) - - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule binop{C : context, Inn : Inn, binop : binop_}: - `%|-%CONST`(C, BINOP_instr((Inn : addrtype <: numtype), binop)) - -- if (Inn <- [I32_Inn I64_Inn]) - -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) - -- wf_context: `%`(C) - -- wf_instr: `%`(BINOP_instr((Inn : addrtype <: numtype), binop)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn)) - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Expr_const: `%|-%CONST`(context, expr) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule _{C : context, `instr*` : instr*}: - `%|-%CONST`(C, instr*{instr <- `instr*`}) - -- (Instr_const: `%|-%CONST`(C, instr))*{instr <- `instr*`} - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) - ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule _{C : context, expr : expr, t : valtype}: - `%|-%:%CONST`(C, expr, t) - -- Expr_ok: `%|-%:%`(C, expr, `%`_resulttype([t])) - -- Expr_const: `%|-%CONST`(C, expr) - -- wf_context: `%`(C) - -- (wf_instr: `%`(expr))*{expr <- expr} - -- wf_valtype: `%`(t) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Type_ok: `%|-%:%`(context, type, deftype*) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx}: - `%|-%:%`(C, TYPE_type(rectype), dt*{dt <- `dt*`}) - -- if (x!`%`_uN.0 = |C.TYPES_context|) - -- if (dt*{dt <- `dt*`} = $rolldt(x, rectype)) - -- Rectype_ok: `%|-%:%`(C +++ {TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rectype, OK_oktypeidx(x)) - -- wf_context: `%`(C) - -- wf_context: `%`({TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- wf_oktypeidx: `%`(OK_oktypeidx(x)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Tag_ok: `%|-%:%`(context, tag, tagtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, tagtype : tagtype}: - `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) - -- Tagtype_ok: `%|-%:OK`(C, tagtype) - -- wf_context: `%`(C) - -- wf_tag: `%`(TAG_tag(tagtype)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Global_ok: `%|-%:%`(context, global, globaltype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, globaltype : globaltype, expr : expr, t : valtype}: - `%|-%:%`(C, GLOBAL_global(globaltype, expr), globaltype) - -- Globaltype_ok: `%|-%:OK`(C, globaltype) - -- if (globaltype = `%%`_globaltype(?(MUT_mut), t)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, t) - -- wf_context: `%`(C) - -- wf_global: `%`(GLOBAL_global(globaltype, expr)) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Mem_ok: `%|-%:%`(context, mem, memtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, memtype : memtype}: - `%|-%:%`(C, MEMORY_mem(memtype), memtype) - -- Memtype_ok: `%|-%:OK`(C, memtype) - -- wf_context: `%`(C) - -- wf_mem: `%`(MEMORY_mem(memtype)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Table_ok: `%|-%:%`(context, table, tabletype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, tabletype : tabletype, expr : expr, at : addrtype, lim : limits, rt : reftype}: - `%|-%:%`(C, TABLE_table(tabletype, expr), tabletype) - -- Tabletype_ok: `%|-%:OK`(C, tabletype) - -- if (tabletype = `%%%`_tabletype(at, lim, rt)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (rt : reftype <: valtype)) - -- wf_context: `%`(C) - -- wf_table: `%`(TABLE_table(tabletype, expr)) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Local_ok: `%|-%:%`(context, local, localtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule set{C : context, t : valtype}: - `%|-%:%`(C, LOCAL_local(t), `%%`_localtype(SET_init, t)) - -- Defaultable: `|-%DEFAULTABLE`(t) - -- wf_context: `%`(C) - -- wf_local: `%`(LOCAL_local(t)) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule unset{C : context, t : valtype}: - `%|-%:%`(C, LOCAL_local(t), `%%`_localtype(UNSET_init, t)) - -- Nondefaultable: `|-%NONDEFAULTABLE`(t) - -- wf_context: `%`(C) - -- wf_local: `%`(LOCAL_local(t)) - -- wf_localtype: `%`(`%%`_localtype(UNSET_init, t)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Func_ok: `%|-%:%`(context, func, deftype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: - `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[x!`%`_uN.0]) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} - -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- wf_context: `%`(C) - -- wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Datamode_ok: `%|-%:%`(context, datamode, datatype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule passive{C : context}: - `%|-%:%`(C, PASSIVE_datamode, OK_datatype) - -- wf_context: `%`(C) - -- wf_datamode: `%`(PASSIVE_datamode) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: - `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) - -- wf_context: `%`(C) - -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Data_ok: `%|-%:%`(context, data, datatype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, `b*` : byte*, datamode : datamode}: - `%|-%:%`(C, DATA_data(b*{b <- `b*`}, datamode), OK_datatype) - -- Datamode_ok: `%|-%:%`(C, datamode, OK_datatype) - -- wf_context: `%`(C) - -- wf_data: `%`(DATA_data(b*{b <- `b*`}, datamode)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule passive{C : context, rt : reftype}: - `%|-%:%`(C, PASSIVE_elemmode, rt) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_elemmode: `%`(PASSIVE_elemmode) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule declare{C : context, rt : reftype}: - `%|-%:%`(C, DECLARE_elemmode, rt) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_elemmode: `%`(DECLARE_elemmode) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: - `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt')) - -- Reftype_sub: `%|-%<:%`(C, rt, rt') - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) - -- wf_context: `%`(C) - -- wf_reftype: `%`(rt) - -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt')) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Elem_ok: `%|-%:%`(context, elem, elemtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, elemtype : elemtype, `expr*` : expr*, elemmode : elemmode}: - `%|-%:%`(C, ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode), elemtype) - -- Reftype_ok: `%|-%:OK`(C, elemtype) - -- (Expr_ok_const: `%|-%:%CONST`(C, expr, (elemtype : reftype <: valtype)))*{expr <- `expr*`} - -- Elemmode_ok: `%|-%:%`(C, elemmode, elemtype) - -- wf_context: `%`(C) - -- wf_elem: `%`(ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Start_ok: `%|-%:OK`(context, start) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, x : idx}: - `%|-%:OK`(C, START_start(x)) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) - -- wf_context: `%`(C) - -- wf_start: `%`(START_start(x)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Import_ok: `%|-%:%`(context, import, externtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, name_1 : name, name_2 : name, xt : externtype}: - `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) - -- Externtype_ok: `%|-%:OK`(C, xt) - -- wf_context: `%`(C) - -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Externidx_ok: `%|-%:%`(context, externidx, externtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule tag{C : context, x : idx, jt : tagtype}: - `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if (C.TAGS_context[x!`%`_uN.0] = jt) - -- wf_context: `%`(C) - -- wf_externidx: `%`(TAG_externidx(x)) - -- wf_externtype: `%`(TAG_externtype(jt)) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule global{C : context, x : idx, gt : globaltype}: - `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if (C.GLOBALS_context[x!`%`_uN.0] = gt) - -- wf_context: `%`(C) - -- wf_externidx: `%`(GLOBAL_externidx(x)) - -- wf_externtype: `%`(GLOBAL_externtype(gt)) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule mem{C : context, x : idx, mt : memtype}: - `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if (C.MEMS_context[x!`%`_uN.0] = mt) - -- wf_context: `%`(C) - -- wf_externidx: `%`(MEM_externidx(x)) - -- wf_externtype: `%`(MEM_externtype(mt)) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule table{C : context, x : idx, tt : tabletype}: - `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if (C.TABLES_context[x!`%`_uN.0] = tt) - -- wf_context: `%`(C) - -- wf_externidx: `%`(TABLE_externidx(x)) - -- wf_externtype: `%`(TABLE_externtype(tt)) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule func{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype((dt : deftype <: typeuse))) - -- if (C.FUNCS_context[x!`%`_uN.0] = dt) - -- wf_context: `%`(C) - -- wf_externidx: `%`(FUNC_externidx(x)) - -- wf_externtype: `%`(FUNC_externtype((dt : deftype <: typeuse))) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Export_ok: `%|-%:%%`(context, export, name, externtype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, name : name, externidx : externidx, xt : externtype}: - `%|-%:%%`(C, EXPORT_export(name, externidx), name, xt) - -- Externidx_ok: `%|-%:%`(C, externidx, xt) - -- wf_context: `%`(C) - -- wf_externtype: `%`(xt) - -- wf_export: `%`(EXPORT_export(name, externidx)) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:136.1-136.100 -relation Globals_ok: `%|-%:%`(context, global*, globaltype*) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:181.1-182.17 - rule empty{C : context}: - `%|-%:%`(C, [], []) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:184.1-187.54 - rule cons{C : context, global_1 : global, `global*` : global*, gt_1 : globaltype, `gt*` : globaltype*}: - `%|-%:%`(C, [global_1] ++ global*{global <- `global*`}, [gt_1] ++ gt*{gt <- `gt*`}) - -- Global_ok: `%|-%:%`(C, global_1, gt_1) - -- Globals_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [gt_1], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- wf_context: `%`(C) - -- wf_global: `%`(global_1) - -- (wf_global: `%`(global))*{global <- `global*`} - -- (wf_globaltype: `%`(gt))*{gt <- `gt*`} - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [gt_1], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -} - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:135.1-135.98 -relation Types_ok: `%|-%:%`(context, type*, deftype*) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:173.1-174.17 - rule empty{C : context}: - `%|-%:%`(C, [], []) - -- wf_context: `%`(C) - - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec:176.1-179.49 - rule cons{C : context, type_1 : type, `type*` : type*, `dt_1*` : deftype*, `dt*` : deftype*}: - `%|-%:%`(C, [type_1] ++ type*{type <- `type*`}, dt_1*{dt_1 <- `dt_1*`} ++ dt*{dt <- `dt*`}) - -- Type_ok: `%|-%:%`(C, type_1, dt_1*{dt_1 <- `dt_1*`}) - -- Types_ok: `%|-%:%`(C +++ {TYPES dt_1*{dt_1 <- `dt_1*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt*{dt <- `dt*`}) - -- wf_context: `%`(C) - -- wf_context: `%`({TYPES dt_1*{dt_1 <- `dt_1*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -} - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -syntax nonfuncs = - | `%%%%%%`(`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation wf_nonfuncs: `%`(nonfuncs) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule nonfuncs_case_0{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}: - `%`(`%%%%%%`_nonfuncs(`global*`, `mem*`, `table*`, `elem*`, `start?`, `export*`)) - -- (wf_global: `%`(global))*{global <- `global*`} - -- (wf_mem: `%`(mem))*{mem <- `mem*`} - -- (wf_table: `%`(table))*{table <- `table*`} - -- (wf_elem: `%`(elem))*{elem <- `elem*`} - -- (wf_start: `%`(start))?{start <- `start?`} - -- (wf_export: `%`(export))*{export <- `export*`} - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -relation Module_ok: `|-%:%`(module, moduletype) - ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: - `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) - -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) - -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} - -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} - -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} - -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} - -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} - -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} - -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} - -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} - -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} - -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) - -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- if (C' = {TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) - -- if (x*{x <- `x*`} = $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))) - -- if (jt_I*{jt_I <- `jt_I*`} = $tagsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (gt_I*{gt_I <- `gt_I*`} = $globalsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (mt_I*{mt_I <- `mt_I*`} = $memsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (tt_I*{tt_I <- `tt_I*`} = $tablesxt(xt_I*{xt_I <- `xt_I*`})) - -- if (dt_I*{dt_I <- `dt_I*`} = $funcsxt(xt_I*{xt_I <- `xt_I*`})) - -- wf_context: `%`(C) - -- wf_context: `%`(C') - -- (wf_name: `%`(nm))*{nm <- `nm*`} - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- wf_context: `%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- wf_context: `%`({TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- wf_context: `%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) - -- wf_nonfuncs: `%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -syntax relaxed2 = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -relation wf_relaxed2: `%`(relaxed2) - ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - rule relaxed2_case_0{i : nat}: - `%`(`%`_relaxed2(i)) - -- if ((i = 0) \/ (i = 1)) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -syntax relaxed4 = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -relation wf_relaxed4: `%`(relaxed4) - ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - rule relaxed4_case_0{i : nat}: - `%`(`%`_relaxed4(i)) - -- if ((((i = 0) \/ (i = 1)) \/ (i = 2)) \/ (i = 3)) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $relaxed2(relaxed2 : relaxed2, syntax X, X : X, X : X) : X - ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $relaxed2{i : relaxed2, syntax X, X_1 : X, X_2 : X}(i, syntax X, X_1, X_2) = (if $ND then [X_1 X_2][i!`%`_relaxed2.0] else [X_1 X_2][0]) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X - ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $relaxed4{i : relaxed4, syntax X, X_1 : X, X_2 : X, X_3 : X, X_4 : X}(i, syntax X, X_1, X_2, X_3, X_4) = (if $ND then [X_1 X_2 X_3 X_4][i!`%`_relaxed4.0] else [X_1 X_2 X_3 X_4][0]) - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_fmadd : relaxed2 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_fmin : relaxed4 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_fmax : relaxed4 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_idot : relaxed2 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_iq15mulr : relaxed2 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_trunc_u : relaxed4 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_trunc_s : relaxed2 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_swizzle : relaxed2 - -;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_laneselect : relaxed2 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $s33_to_u32(s33 : s33) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ibits_(N : N, iN : iN) : bit* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fbits_(N : N, fN : fN) : bit* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ibytes_(N : N, iN : iN) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fbytes_(N : N, fN : fN) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $nbytes_(numtype : numtype, num_ : num_) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $vbytes_(vectype : vectype, vec_ : vec_) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_ibits_(N : N, bit*) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_fbits_(N : N, bit*) : fN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_ibytes_(N : N, byte*) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_fbytes_(N : N, byte*) : fN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_nbytes_(numtype : numtype, byte*) : num_ - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_vbytes_(vectype : vectype, byte*) : vec_ - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = (i : nat <:> int) - -- if (i < (2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = ((i : nat <:> int) - ((2 ^ N) : nat <:> int)) - -- if (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) <= i) /\ (i < (2 ^ N))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_signed_(N : N, int : int) : nat - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = (i : int <:> nat) - -- if (((0 : nat <:> int) <= i) /\ (i < ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = ((i + ((2 ^ N) : nat <:> int)) : int <:> nat) - -- if ((- ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= i) /\ (i < (0 : nat <:> int))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $sx(storagetype : storagetype) : sx?? - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{consttype : consttype}((consttype : consttype <: storagetype)) = ?(?()) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{packtype : packtype}((packtype : packtype <: storagetype)) = ?(?(S_sx)) - def $sx{x0 : storagetype}(x0) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $zero(lanetype : lanetype) : lane_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $bool(bool : bool) : nat - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $bool(false) = 0 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $bool(true) = 1 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $truncz(rat : rat) : int - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ceilz(rat : rat) : int - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $sat_u_(N : N, int : int) : nat - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sat_u_{N : nat, i : int}(N, i) = (if (i < (0 : nat <:> int)) then 0 else (if (i > (((2 ^ N) : nat <:> int) - (1 : nat <:> int))) then ((((2 ^ N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat) else (i : int <:> nat))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $sat_s_(N : N, int : int) : int - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sat_s_{N : nat, i : int}(N, i) = (if (i < - ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) then - ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) else (if (i > (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))) then (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int)) else i)) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ineg_(N : N, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iabs_(N : N, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iabs_{N : nat, i_1 : uN}(N, i_1) = (if ($signed_(N, i_1!`%`_uN.0) >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iclz_(N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ictz_(N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ipopcnt_(N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN((i!`%`_uN.0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN((i!`%`_uN.0 \ (2 ^ M)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M)))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iadd_(N : N, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $isub_(N : N, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $imul_(N : N, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?() - -- if ((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -- if ((j_1 = $signed_(N, i_1!`%`_uN.0)) /\ (j_2 = $signed_(N, i_2!`%`_uN.0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_1 - -- if (i_1!`%`_uN.0 <= i_2!`%`_uN.0) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 - -- if (i_1!`%`_uN.0 > i_2!`%`_uN.0) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)) then i_1 else i_2) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_1 - -- if (i_1!`%`_uN.0 >= i_2!`%`_uN.0) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 - -- if (i_1!`%`_uN.0 < i_2!`%`_uN.0) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)) then i_1 else i_2) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0)))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int))))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0)))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irelaxed_q15mulr_(N : N, sx : sx, iN : iN, iN : iN) : iN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iavgr_(N : N, sx : sx, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inot_(N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irev_(N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iand_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iandnot_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ior_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ixor_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ishl_(N : N, iN : iN, u32 : u32) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ishr_(N : N, sx : sx, iN : iN, u32 : u32) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irotl_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irotr_(N : N, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ibitselect_(N : N, iN : iN, iN : iN, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ieqz_(N : N, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 = 0)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inez_(N : N, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 =/= 0)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ieq_(N : N, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ine_(N : N, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0))))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fabs_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fneg_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fge_(N : N, fN : fN, fN : fN) : u32 - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $wrap__(M : M, N : N, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $extend__(M : M, N : N, sx : sx, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $trunc__(M : M, N : N, sx : sx, fN : fN) : iN? - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $trunc_sat__(M : M, N : N, sx : sx, fN : fN) : iN? - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $demote__(M : M, N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $promote__(M : M, N : N, fN : fN) : fN* - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $convert__(M : M, N : N, sx : sx, iN : iN) : fN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $testop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_testop__0_testop_(Inn, EQZ_testop_Inn), mk_num__0_num_(Inn, i)) = $ieqz_($sizenn((Inn : addrtype <: numtype)), i) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, EQ_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ieq_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, NE_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ine_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ilt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $igt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ile_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ige_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, EQ_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $feq_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, NE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fne_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $flt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fgt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fle_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fge_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] - -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] - -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lanes_(shape : shape, vec_ : vec_) : lane_* - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $inv_lanes_(shape : shape, lane_*) : vec_ - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = half?{half <- `half?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $half(half : half, nat : nat, nat : nat) : nat - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(LOW_half, i, j) = i - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(HIGH_half, i, j) = j - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $iswizzle_lane_(N : N, iN*, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else (if ($signed_(N, i!`%`_uN.0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[(i!`%`_uN.0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_uN: `%%`(1, `%`_uN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_bit: `%`(`%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)))*{c_1 <- `c_1*`} - -- wf_bit: `%`(`%`_bit(0)) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{Jnn : Jnn, M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{Jnn : Jnn, M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c*{c <- `c*`} = c_1*{c_1 <- `c_1*`} ++ c_2*{c_2 <- `c_2*`}[i!`%`_uN.0]*{i <- `i*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvunop_(vectype : vectype, vvunop : vvunop, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvunop_{Vnn : vectype, v : uN}(Vnn, NOT_vvunop, v) = [$inot_($vsizenn(Vnn), v)] - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, AND_vvbinop, v_1, v_2) = [$iand_($vsizenn(Vnn), v_1, v_2)] - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, ANDNOT_vvbinop, v_1, v_2) = [$iandnot_($vsizenn(Vnn), v_1, v_2)] - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, OR_vvbinop, v_1, v_2) = [$ior_($vsizenn(Vnn), v_1, v_2)] - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, XOR_vvbinop, v_1, v_2) = [$ixor_($vsizenn(Vnn), v_1, v_2)] - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] - -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] - -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v - -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), sx, v_1, v_2) = v - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c'_1)*{c'_1 <- `c'_1*`} ++ mk_lane__2_lane_(Jnn_2, c'_2)*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_1)))*{c'_1 <- `c'_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_2)))*{c'_2 <- `c'_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivadd_pairwise_(N : N, iN*) : iN* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = i!`%`_uN.0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_(N : N, iN*, iN*) : iN* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_sat_(N : N, iN*, iN*) : iN* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1)[i!`%`_uN.0 : k!`%`_uN.0] - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2)[i!`%`_uN.0 : k!`%`_uN.0] - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivmul_(N : N, iN*, iN*) : iN* - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c - -- if ($jsizenn(Jnn) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) - -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M)) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax num = - | CONST(numtype : numtype, num_) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_num: `%`(num) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule num_case_0{numtype : numtype, var_0 : num_}: - `%`(CONST_num(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax vec = - | VCONST(vectype : vectype, vec_) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_vec: `%`(vec) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule vec_case_0{vectype : vectype, var_0 : vec_}: - `%`(VCONST_vec(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax result = - | _VALS(`val*` : val*) - | `(REF.EXN_ADDR%)THROW_REF`(exnaddr : exnaddr) - | TRAP - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_result: `%`(result) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_0{`val*` : val*}: - `%`(_VALS_result(`val*`)) - -- (wf_val: `%`(val))*{val <- `val*`} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_1{exnaddr : exnaddr}: - `%`(`(REF.EXN_ADDR%)THROW_REF`_result(exnaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_2: - `%`(TRAP_result) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax hostfunc = - | `...` - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funccode = - | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) - | `...` - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_funccode: `%`(funccode) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funccode_case_0{typeidx : typeidx, `local*` : local*, expr : expr}: - `%`(FUNC_funccode(typeidx, `local*`, expr)) - -- wf_uN: `%%`(32, typeidx) - -- (wf_local: `%`(local))*{local <- `local*`} - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funccode_case_1: - `%`(`...`_funccode) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax taginst = -{ - TYPE tagtype -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_taginst: `%`(taginst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule taginst_case_{var_0 : tagtype}: - `%`({TYPE var_0}) - -- wf_typeuse: `%`(var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax globalinst = -{ - TYPE globaltype, - VALUE val -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_globalinst: `%`(globalinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule globalinst_case_{var_0 : globaltype, var_1 : val}: - `%`({TYPE var_0, VALUE var_1}) - -- wf_globaltype: `%`(var_0) - -- wf_val: `%`(var_1) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax meminst = -{ - TYPE memtype, - BYTES byte* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_meminst: `%`(meminst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule meminst_case_{var_0 : memtype, var_1 : byte*}: - `%`({TYPE var_0, BYTES var_1}) - -- wf_memtype: `%`(var_0) - -- (wf_byte: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax tableinst = -{ - TYPE tabletype, - REFS ref* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_tableinst: `%`(tableinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule tableinst_case_{var_0 : tabletype, var_1 : ref*}: - `%`({TYPE var_0, REFS var_1}) - -- wf_tabletype: `%`(var_0) - -- (wf_ref: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funcinst = -{ - TYPE deftype, - MODULE moduleinst, - CODE funccode -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_funcinst: `%`(funcinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funcinst_case_{var_0 : deftype, var_1 : moduleinst, var_2 : funccode}: - `%`({TYPE var_0, MODULE var_1, CODE var_2}) - -- wf_moduleinst: `%`(var_1) - -- wf_funccode: `%`(var_2) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax datainst = -{ - BYTES byte* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_datainst: `%`(datainst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule datainst_case_{var_0 : byte*}: - `%`({BYTES var_0}) - -- (wf_byte: `%`(var_0))*{var_0 <- var_0} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax eleminst = -{ - TYPE elemtype, - REFS ref* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_eleminst: `%`(eleminst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule eleminst_case_{var_0 : elemtype, var_1 : ref*}: - `%`({TYPE var_0, REFS var_1}) - -- wf_reftype: `%`(var_0) - -- (wf_ref: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax packval = - | PACK(packtype : packtype, iN) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_packval: `%`(packval) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule packval_case_0{packtype : packtype, var_0 : iN}: - `%`(PACK_packval(packtype, var_0)) - -- wf_uN: `%%`($psize(packtype), var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax fieldval = - | CONST(numtype : numtype, num_) - | VCONST(vectype : vectype, vec_) - | `REF.I31_NUM`(u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(structaddr : structaddr) - | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(funcaddr : funcaddr) - | `REF.EXN_ADDR`(exnaddr : exnaddr) - | `REF.HOST_ADDR`(hostaddr : hostaddr) - | `REF.EXTERN`(ref : ref) - | PACK(packtype : packtype, iN) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_fieldval: `%`(fieldval) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_0{numtype : numtype, var_0 : num_}: - `%`(CONST_fieldval(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_1{vectype : vectype, var_0 : vec_}: - `%`(VCONST_fieldval(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_2{u31 : u31}: - `%`(`REF.I31_NUM`_fieldval(u31)) - -- wf_uN: `%%`(31, u31) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_3: - `%`(`REF.NULL_ADDR`_fieldval) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_4{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_fieldval(structaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_5{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_fieldval(arrayaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_6{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_fieldval(funcaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_7{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_fieldval(exnaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_8{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(hostaddr)) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_9{ref : ref}: - `%`(`REF.EXTERN`_fieldval(ref)) - -- wf_ref: `%`(ref) - - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_10{packtype : packtype, var_0 : iN}: - `%`(PACK_fieldval(packtype, var_0)) - -- wf_uN: `%%`($psize(packtype), var_0) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structinst = -{ - TYPE deftype, - FIELDS fieldval* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_structinst: `%`(structinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule structinst_case_{var_0 : deftype, var_1 : fieldval*}: - `%`({TYPE var_0, FIELDS var_1}) - -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayinst = -{ - TYPE deftype, - FIELDS fieldval* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_arrayinst: `%`(arrayinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule arrayinst_case_{var_0 : deftype, var_1 : fieldval*}: - `%`({TYPE var_0, FIELDS var_1}) - -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exninst = -{ - TAG tagaddr, - FIELDS val* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_exninst: `%`(exninst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule exninst_case_{var_0 : tagaddr, var_1 : val*}: - `%`({TAG var_0, FIELDS var_1}) - -- (wf_val: `%`(var_1))*{var_1 <- var_1} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax store = -{ - TAGS taginst*, - GLOBALS globalinst*, - MEMS meminst*, - TABLES tableinst*, - FUNCS funcinst*, - DATAS datainst*, - ELEMS eleminst*, - STRUCTS structinst*, - ARRAYS arrayinst*, - EXNS exninst* -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_store: `%`(store) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule store_case_{var_0 : taginst*, var_1 : globalinst*, var_2 : meminst*, var_3 : tableinst*, var_4 : funcinst*, var_5 : datainst*, var_6 : eleminst*, var_7 : structinst*, var_8 : arrayinst*, var_9 : exninst*}: - `%`({TAGS var_0, GLOBALS var_1, MEMS var_2, TABLES var_3, FUNCS var_4, DATAS var_5, ELEMS var_6, STRUCTS var_7, ARRAYS var_8, EXNS var_9}) - -- (wf_taginst: `%`(var_0))*{var_0 <- var_0} - -- (wf_globalinst: `%`(var_1))*{var_1 <- var_1} - -- (wf_meminst: `%`(var_2))*{var_2 <- var_2} - -- (wf_tableinst: `%`(var_3))*{var_3 <- var_3} - -- (wf_funcinst: `%`(var_4))*{var_4 <- var_4} - -- (wf_datainst: `%`(var_5))*{var_5 <- var_5} - -- (wf_eleminst: `%`(var_6))*{var_6 <- var_6} - -- (wf_structinst: `%`(var_7))*{var_7 <- var_7} - -- (wf_arrayinst: `%`(var_8))*{var_8 <- var_8} - -- (wf_exninst: `%`(var_9))*{var_9 <- var_9} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax state = - | `%;%`(store : store, frame : frame) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_state: `%`(state) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule state_case_0{store : store, frame : frame}: - `%`(`%;%`_state(store, frame)) - -- wf_store: `%`(store) - -- wf_frame: `%`(frame) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax config = - | `%;%`(state : state, `instr*` : instr*) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_config: `%`(config) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule config_case_0{state : state, `instr*` : instr*}: - `%`(`%;%`_config(state, `instr*`)) - -- wf_state: `%`(state) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $Ki : nat - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $packfield_(storagetype : storagetype, val : val) : fieldval? - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = ?((val : val <: fieldval)) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = ?(val) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.1-190.86 -def $tagsxa(externaddr*) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:196.1-196.23 - def $tagsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:197.1-197.42 - def $tagsxa{a : nat, `xa*` : externaddr*}([TAG_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tagsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:198.1-198.57 - def $tagsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tagsxa(xa*{xa <- `xa*`}) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.1-191.89 -def $globalsxa(externaddr*) : globaladdr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:200.1-200.26 - def $globalsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:201.1-201.51 - def $globalsxa{a : nat, `xa*` : externaddr*}([GLOBAL_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $globalsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:202.1-202.63 - def $globalsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $globalsxa(xa*{xa <- `xa*`}) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.1-192.86 -def $memsxa(externaddr*) : memaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:204.1-204.23 - def $memsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:205.1-205.42 - def $memsxa{a : nat, `xa*` : externaddr*}([MEM_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $memsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:206.1-206.57 - def $memsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $memsxa(xa*{xa <- `xa*`}) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.1-193.88 -def $tablesxa(externaddr*) : tableaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:208.1-208.25 - def $tablesxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:209.1-209.48 - def $tablesxa{a : nat, `xa*` : externaddr*}([TABLE_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tablesxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:210.1-210.61 - def $tablesxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tablesxa(xa*{xa <- `xa*`}) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.1-194.87 -def $funcsxa(externaddr*) : funcaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:212.1-212.24 - def $funcsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:213.1-213.45 - def $funcsxa{a : nat, `xa*` : externaddr*}([FUNC_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $funcsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:214.1-214.59 - def $funcsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $funcsxa(xa*{xa <- `xa*`}) -} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $store(state : state) : store - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $store{s : store, f : frame}(`%;%`_state(s, f)) = s - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $frame(state : state) : frame - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tagaddr(state : state) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tagaddr{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame.TAGS_moduleinst - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $moduleinst(state : state) : moduleinst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $taginst(state : state) : taginst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $globalinst(state : state) : globalinst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $meminst(state : state) : meminst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tableinst(state : state) : tableinst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $funcinst(state : state) : funcinst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $datainst(state : state) : datainst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $eleminst(state : state) : eleminst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $structinst(state : state) : structinst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $arrayinst(state : state) : arrayinst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $exninst(state : state) : exninst* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fof(state : state) : frame - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fof{z : state}(z) = $frame(z) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $type(state : state, typeidx : typeidx) : deftype - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $type{z : state, x : uN}(z, x) = $fof(z).MODULE_frame.TYPES_moduleinst[x!`%`_uN.0] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $sof(state : state) : store - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $sof{z : state}(z) = $store(z) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tag(state : state, tagidx : tagidx) : taginst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $global(state : state, globalidx : globalidx) : globalinst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $mem(state : state, memidx : memidx) : meminst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $table(state : state, tableidx : tableidx) : tableinst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $func(state : state, funcidx : funcidx) : funcinst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $data(state : state, dataidx : dataidx) : datainst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $elem(state : state, tableidx : tableidx) : eleminst - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $local(state : state, localidx : localidx) : val? - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[x!`%`_uN.0] - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_local(state : state, localidx : localidx, val : val) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)])) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_global(state : state, globalidx : globalidx, val : val) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_elem(state : state, elemidx : elemidx, ref*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_data(state : state, dataidx : dataidx, byte*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_structinst(state : state, structinst*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_arrayinst(state : state, arrayinst*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_exninst(state : state, exninst*) : state - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}(tableinst, n, r) = ?(tableinst') - -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}} = tableinst - -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - -- if (i'!`%`_uN.0 = (|r'*{r' <- `r'*`}| + n)) - -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} - -- if ((i'!`%`_uN.0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(meminst : meminst, nat : nat) : meminst? - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if ((i'!`%`_uN.0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) - -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} - -- if (i'!`%`_uN.0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -relation Num_ok: `%|-%:%`(store, num, numtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule _{s : store, nt : numtype, c : num_}: - `%|-%:%`(s, CONST_num(nt, c), nt) - -- wf_store: `%`(s) - -- wf_num: `%`(CONST_num(nt, c)) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -relation Vec_ok: `%|-%:%`(store, vec, vectype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule _{s : store, vt : vectype, c : vec_}: - `%|-%:%`(s, VCONST_vec(vt, c), vt) - -- wf_store: `%`(s) - -- wf_vec: `%`(VCONST_vec(vt, c)) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:25.1-25.60 -relation Ref_ok: `%|-%:%`(store, ref, reftype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:35.1-36.36 - rule null{s : store}: - `%|-%:%`(s, `REF.NULL_ADDR`_ref, REF_reftype(?(NULL_null), BOT_heaptype)) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), BOT_heaptype)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:38.1-39.31 - rule i31{s : store, i : u31}: - `%|-%:%`(s, `REF.I31_NUM`_ref(i), REF_reftype(?(), I31_heaptype)) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.I31_NUM`_ref(i)) - -- wf_reftype: `%`(REF_reftype(?(), I31_heaptype)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 - rule struct{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (s.STRUCTS_store[a].TYPE_structinst = dt) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 - rule array{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 - rule func{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (s.FUNCS_store[a].TYPE_funcinst = dt) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 - rule exn{s : store, a : addr, exn : exninst}: - `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (s.EXNS_store[a] = exn) - -- wf_store: `%`(s) - -- wf_exninst: `%`(exn) - -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.33 - rule host{s : store, a : addr}: - `%|-%:%`(s, `REF.HOST_ADDR`_ref(a), REF_reftype(?(), ANY_heaptype)) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.HOST_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), ANY_heaptype)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:60.1-63.30 - rule extern{s : store, ref : ref}: - `%|-%:%`(s, `REF.EXTERN`_ref(ref), REF_reftype(?(), EXTERN_heaptype)) - -- Ref_ok: `%|-%:%`(s, ref, REF_reftype(?(), ANY_heaptype)) - -- if (ref =/= `REF.NULL_ADDR`_ref) - -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.EXTERN`_ref(ref)) - -- wf_reftype: `%`(REF_reftype(?(), EXTERN_heaptype)) - -- wf_reftype: `%`(REF_reftype(?(), ANY_heaptype)) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:65.1-69.34 - rule sub{s : store, ref : ref, rt : reftype, rt' : reftype}: - `%|-%:%`(s, ref, rt) - -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', rt) - -- wf_store: `%`(s) - -- wf_ref: `%`(ref) - -- wf_reftype: `%`(rt) - -- wf_reftype: `%`(rt') - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -} - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -relation Val_ok: `%|-%:%`(store, val, valtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule num{s : store, num : num, nt : numtype}: - `%|-%:%`(s, (num : num <: val), (nt : numtype <: valtype)) - -- Num_ok: `%|-%:%`(s, num, nt) - -- wf_store: `%`(s) - -- wf_num: `%`(num) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule vec{s : store, vec : vec, vt : vectype}: - `%|-%:%`(s, (vec : vec <: val), (vt : vectype <: valtype)) - -- Vec_ok: `%|-%:%`(s, vec, vt) - -- wf_store: `%`(s) - -- wf_vec: `%`(vec) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule ref{s : store, ref : ref, rt : reftype}: - `%|-%:%`(s, (ref : ref <: val), (rt : reftype <: valtype)) - -- Ref_ok: `%|-%:%`(s, ref, rt) - -- wf_store: `%`(s) - -- wf_ref: `%`(ref) - -- wf_reftype: `%`(rt) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -relation Packval_ok: `%|-%:%`(store, packval, packtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule _{s : store, pt : packtype, c : iN}: - `%|-%:%`(s, PACK_packval(pt, c), pt) - -- wf_store: `%`(s) - -- wf_packval: `%`(PACK_packval(pt, c)) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -relation Fieldval_ok: `%|-%:%`(store, fieldval, storagetype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule val{s : store, val : val, t : valtype}: - `%|-%:%`(s, (val : val <: fieldval), (t : valtype <: storagetype)) - -- Val_ok: `%|-%:%`(s, val, t) - -- wf_store: `%`(s) - -- wf_val: `%`(val) - -- wf_valtype: `%`(t) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - rule packval{s : store, packval : packval, pt : packtype}: - `%|-%:%`(s, (packval : packval <: fieldval), (pt : packtype <: storagetype)) - -- Packval_ok: `%|-%:%`(s, packval, pt) - -- wf_store: `%`(s) - -- wf_packval: `%`(packval) - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:104.1-104.84 -relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 - rule tag{s : store, a : addr, taginst : taginst}: - `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) - -- if (s.TAGS_store[a] = taginst) - -- wf_store: `%`(s) - -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 - rule global{s : store, a : addr, globalinst : globalinst}: - `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (s.GLOBALS_store[a] = globalinst) - -- wf_store: `%`(s) - -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 - rule mem{s : store, a : addr, meminst : meminst}: - `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) - -- if (s.MEMS_store[a] = meminst) - -- wf_store: `%`(s) - -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 - rule table{s : store, a : addr, tableinst : tableinst}: - `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (s.TABLES_store[a] = tableinst) - -- wf_store: `%`(s) - -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 - rule func{s : store, a : addr, funcinst : funcinst}: - `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) - -- if (s.FUNCS_store[a] = funcinst) - -- wf_store: `%`(s) - -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) - - ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:126.1-130.37 - rule sub{s : store, externaddr : externaddr, xt : externtype, xt' : externtype}: - `%|-%:%`(s, externaddr, xt) - -- Externaddr_ok: `%|-%:%`(s, externaddr, xt') - -- Externtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, xt) - -- Externtype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, xt', xt) - -- wf_store: `%`(s) - -- wf_externtype: `%`(xt) - -- wf_externtype: `%`(xt') - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -} - -;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype - ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) - -;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype - ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) - -;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype - ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) - -;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype - ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) - -;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype - ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation Step_pure: `%~>%`(instr*, instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule unreachable: - `%~>%`([UNREACHABLE_instr], [TRAP_instr]) - -- wf_instr: `%`(UNREACHABLE_instr) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule nop: - `%~>%`([NOP_instr], []) - -- wf_instr: `%`(NOP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule drop{val : val}: - `%~>%`([(val : val <: instr) DROP_instr], []) - -- wf_val: `%`(val) - -- wf_instr: `%`(DROP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_1 : val <: instr)]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) - -- wf_val: `%`(val_1) - -- wf_val: `%`(val_2) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_2 : val <: instr)]) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) - -- wf_val: `%`(val_1) - -- wf_val: `%`(val_2) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: - `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) - -- wf_instr: `%`(BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: - `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) - -- wf_instr: `%`(BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `label-vals`{n : n, `instr*` : instr*, `val*` : val*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br-label-zero`{n : n, `instr'*` : instr*, `val'*` : val*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) - -- if (l!`%`_uN.0 = 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(`%`_labelidx((((l!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) - -- if (l!`%`_uN.0 > 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(BR_instr(`%`_labelidx((((l!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br-handler`{n : n, `catch*` : catch*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_if-true`{c : num_, l : labelidx}: - `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(BR_IF_instr(l)) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_if-false`{c : num_, l : labelidx}: - `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_instr: `%`(BR_IF_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_table-lt`{i : num_, `l*` : labelidx*, l' : labelidx}: - `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[!($proj_num__0(i))!`%`_uN.0])]) - -- if (!($proj_num__0(i))!`%`_uN.0 < |l*{l <- `l*`}|) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) - -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[!($proj_num__0(i))!`%`_uN.0])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: - `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |l*{l <- `l*`}|) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) - -- wf_instr: `%`(BR_instr(l')) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [BR_instr(l)]) - -- if (val = `REF.NULL_ADDR`_val) - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NULL_instr(l)) - -- wf_instr: `%`(BR_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [(val : val <: instr)]) - -- otherwise - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NULL_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_non_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], []) - -- if (val = `REF.NULL_ADDR`_val) - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_non_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], [(val : val <: instr) BR_instr(l)]) - -- otherwise - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule call_indirect{x : idx, yy : typeuse}: - `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) CALL_REF_instr(yy)]) - -- wf_instr: `%`(CALL_INDIRECT_instr(x, yy)) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) - -- wf_instr: `%`(CALL_REF_instr(yy)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule return_call_indirect{x : idx, yy : typeuse}: - `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) RETURN_CALL_REF_instr(yy)]) - -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, yy)) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) - -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `frame-vals`{n : n, f : frame, `val*` : val*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(RETURN_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return-handler`{n : n, `catch*` : catch*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(RETURN_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `handler-vals`{n : n, `catch*` : catch*, `val*` : val*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `trap-instrs`{`val*` : val*, `instr*` : instr*}: - `%~>%`((val : val <: instr)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) - -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) - -- (wf_val: `%`(val))*{val <- `val*`} - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `trap-label`{n : n, `instr'*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, [TRAP_instr])], [TRAP_instr]) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, [TRAP_instr])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `trap-handler`{n : n, `catch*` : catch*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [TRAP_instr])], [TRAP_instr]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [TRAP_instr])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `trap-frame`{n : n, f : frame}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, [TRAP_instr])], [TRAP_instr]) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, [TRAP_instr])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `local.tee`{val : val, x : idx}: - `%~>%`([(val : val <: instr) `LOCAL.TEE`_instr(x)], [(val : val <: instr) (val : val <: instr) `LOCAL.SET`_instr(x)]) - -- wf_val: `%`(val) - -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) - -- wf_instr: `%`(`LOCAL.SET`_instr(x)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.i31`{i : num_}: - `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`REF.I31`_instr) - -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.is_null-true`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.is_null-false`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- otherwise - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.as_non_null-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [TRAP_instr]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - -- wf_instr: `%`(TRAP_instr) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.as_non_null-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [(ref : ref <: instr)]) - -- otherwise - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.eq-null`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) - -- wf_ref: `%`(ref_1) - -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.eq-true`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- otherwise - -- if (ref_1 = ref_2) - -- wf_ref: `%`(ref_1) - -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.eq-false`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- otherwise - -- wf_ref: `%`(ref_1) - -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `i31.get-null`{sx : sx}: - `%~>%`([`REF.NULL_ADDR`_instr `I31.GET`_instr(sx)], [TRAP_instr]) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - -- wf_instr: `%`(`I31.GET`_instr(sx)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `i31.get-num`{i : u31, sx : sx}: - `%~>%`([`REF.I31_NUM`_instr(i) `I31.GET`_instr(sx)], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, $extend__(31, 32, sx, i)))]) - -- wf_instr: `%`(`REF.I31_NUM`_instr(i)) - -- wf_instr: `%`(`I31.GET`_instr(sx)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, $extend__(31, 32, sx, i)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new`{val : val, n : n, x : idx}: - `%~>%`([(val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW`_instr(x)], (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- wf_val: `%`(val) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `extern.convert_any-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `extern.convert_any-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) - -- otherwise - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `any.convert_extern-null`: - `%~>%`([`REF.NULL_ADDR`_instr `ANY.CONVERT_EXTERN`_instr], [`REF.NULL_ADDR`_instr]) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `any.convert_extern-addr`{ref : ref}: - `%~>%`([`REF.EXTERN`_instr(ref) `ANY.CONVERT_EXTERN`_instr], [(ref : ref <: instr)]) - -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: - `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (c <- $unop_(nt, unop, c_1)) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(UNOP_instr(nt, unop)) - -- wf_instr: `%`(CONST_instr(nt, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: - `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) - -- if ($unop_(nt, unop, c_1) = []) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(UNOP_instr(nt, unop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: - `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (c <- $binop_(nt, binop, c_1, c_2)) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_instr: `%`(BINOP_instr(nt, binop)) - -- wf_instr: `%`(CONST_instr(nt, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: - `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) - -- if ($binop_(nt, binop, c_1, c_2) = []) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_instr: `%`(BINOP_instr(nt, binop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: - `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(TESTOP_instr(nt, testop)) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: - `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) - -- wf_instr: `%`(CONST_instr(nt, c_1)) - -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_instr: `%`(RELOP_instr(nt, relop)) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: - `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) - -- wf_instr: `%`(CONST_instr(nt_1, c_1)) - -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) - -- wf_instr: `%`(CONST_instr(nt_2, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: - `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) - -- wf_instr: `%`(CONST_instr(nt_1, c_1)) - -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) - -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, vvternop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvtestop{c_1 : vec_, c : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vunop_(sh, vunop, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VUNOP_instr(sh, vunop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) - -- if ($vunop_(sh, vunop, c_1) = []) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VUNOP_instr(sh, vunop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) - -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) - -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) - -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) - -- if (!($proj_num__0(c))!`%`_uN.0 = $prod($inez_($jsizenn(Jnn), !($proj_lane__2(i)))!`%`_uN.0*{i <- `i*`})) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) - -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VBITMASK_instr(sh)) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: - `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) - -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) - -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) - -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape(Lnn, `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0]) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) - -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) - -- wf_shape: `%`(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) - -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) - -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) - -- wf_shape: `%`(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) - -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape(Lnn, `%`_dim(M))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) - -- wf_instr: `%`(VEXTTERNOP_instr(sh_2, sh_1, vextternop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) - -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -def $blocktype_(state : state, blocktype : blocktype) : instrtype - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation Step_read: `%~>%`(config, instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) - -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `call_ref-null`{z : state, yy : typeuse}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CALL_REF_instr(yy)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CALL_REF_instr(yy)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) - -- if ($funcinst(z)[a] = fi) - -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule return_call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) - -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return_call_ref-label`{z : state, k : n, `instr'*` : instr*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) - -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return_call_ref-handler`{z : state, k : n, `catch*` : catch*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) - -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return_call_ref-frame-null`{z : state, k : n, f : frame, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) - -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(CALL_REF_instr(yy)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-null`{z : state}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr THROW_REF_instr]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr THROW_REF_instr])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-instrs`{z : state, `val*` : val*, a : addr, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(THROW_REF_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-label`{z : state, n : n, `instr'*` : instr*, a : addr}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(THROW_REF_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-frame`{z : state, n : n, f : frame, a : addr}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(n, f, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(n, f, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(THROW_REF_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-empty`{z : state, n : n, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [], [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [], [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(THROW_REF_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) - -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) - -- (wf_val: `%`(val))*{val <- `val*`} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) - -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) - -- (wf_val: `%`(val))*{val <- `val*`} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-catch_all`{z : state, n : n, l : labelidx, `catch'*` : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_ALL_catch(l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [BR_instr(l)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_ALL_catch(l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-catch_all_ref`{z : state, n : n, l : labelidx, `catch'*` : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_ALL_REF_catch(l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_ALL_REF_catch(l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) - -- wf_instr: `%`(BR_instr(l)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `throw_ref-handler-next`{z : state, n : n, catch : catch, `catch'*` : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [catch] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`HANDLER_%{%}%`_instr(n, catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [catch] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `local.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) - -- if ($local(z, x) = ?(val)) - -- wf_val: `%`(val) - -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `global.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) - -- if ($global(z, x).VALUE_globalinst = val) - -- wf_val: `%`(val) - -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[!($proj_num__0(i))!`%`_uN.0] : ref <: instr)]) - -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: - `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) - -- if (|$table(z, x).REFS_tableinst| = n) - -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) - -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.FILL`_instr(x)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- otherwise - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(`TABLE.GET`_instr(y)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.GET`_instr(y)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) - -- wf_instr: `%`(CONST_instr(nt, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) - -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) - -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- if (N = $jsize(Jnn)) - -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- if (c = $extend__(N, 128, U_sx, j)) - -- wf_uN: `%%`(N, j) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- if (N = $jsize(Jnn)) - -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.size`{z : state, x : idx, at : addrtype, n : n, lim : limits}: - `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) - -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) - -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) - -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- otherwise - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0]!`%`_byte.0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0]!`%`_byte.0)))) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.null`{z : state, ht : heaptype}: - `%~>%`(`%;%`_config(z, [`REF.NULL`_instr(ht)]), [`REF.NULL_ADDR`_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL`_instr(ht)])) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.func`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0])]) - -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-false`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- otherwise - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-fail`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [TRAP_instr]) - -- otherwise - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), (val : val <: instr)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) - -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} - -- (wf_val: `%`(val))*{val <- `val*`} - -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `struct.get-null`{z : state, `sx?` : sx?, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0])) : val <: instr)]) - -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (!($default_($unpack(zt))) = ?(val)) - -- wf_val: `%`(val) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[!($proj_num__0(i))!`%`_uN.0 : n]) - -- (wf_ref: `%`(ref))*{ref <- `ref*`} - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(i))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[!($proj_num__0(i))!`%`_uN.0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0])) : val <: instr)]) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.len-null`{z : state}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `ARRAY.LEN`_instr]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `ARRAY.LEN`_instr])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.len-array`{z : state, a : addr}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.fill-null`{z : state, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- otherwise - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-null1`{z : state, i_1 : num_, ref : ref, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-null2`{z : state, ref : ref, i_1 : num_, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- otherwise - -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- otherwise - -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_elem-null`{z : state, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- otherwise - -- if (ref = $elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0]) - -- wf_ref: `%`(ref) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-null`{z : state, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), []) - -- otherwise - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- otherwise - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_lit_: `%%`(zt, c) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) - -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:5.1-5.88 -relation Step: `%~>%`(config, config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:13.1-15.34 - rule pure{z : state, `instr*` : instr*, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z, instr'*{instr' <- `instr'*`})) - -- Step_pure: `%~>%`(instr*{instr <- `instr*`}, instr'*{instr' <- `instr'*`}) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z, instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:17.1-19.37 - rule read{z : state, `instr*` : instr*, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z, instr'*{instr' <- `instr'*`})) - -- Step_read: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), instr'*{instr' <- `instr'*`}) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z, instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:32.1-35.41 - rule `ctxt-instrs`{z : state, `val*` : val*, `instr*` : instr*, `instr_1*` : instr*, z' : state, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) - -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) - -- if ((val*{val <- `val*`} =/= []) \/ (instr_1*{instr_1 <- `instr_1*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:37.1-39.36 - rule `ctxt-label`{z : state, n : n, `instr_0*` : instr*, `instr*` : instr*, z' : state, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(n, instr_0*{instr_0 <- `instr_0*`}, instr*{instr <- `instr*`})]), `%;%`_config(z', [`LABEL_%{%}%`_instr(n, instr_0*{instr_0 <- `instr_0*`}, instr'*{instr' <- `instr'*`})])) - -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(n, instr_0*{instr_0 <- `instr_0*`}, instr*{instr <- `instr*`})])) - -- wf_config: `%`(`%;%`_config(z', [`LABEL_%{%}%`_instr(n, instr_0*{instr_0 <- `instr_0*`}, instr'*{instr' <- `instr'*`})])) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:41.1-43.36 - rule `ctxt-handler`{z : state, n : n, `catch*` : catch*, `instr*` : instr*, z' : state, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr*{instr <- `instr*`})]), `%;%`_config(z', [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr'*{instr' <- `instr'*`})])) - -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr*{instr <- `instr*`})])) - -- wf_config: `%`(`%;%`_config(z', [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr'*{instr' <- `instr'*`})])) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:45.1-47.45 - rule `ctxt-frame`{s : store, f : frame, n : n, f' : frame, `instr*` : instr*, s' : store, f'' : frame, `instr'*` : instr*}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [`FRAME_%{%}%`_instr(n, f', instr*{instr <- `instr*`})]), `%;%`_config(`%;%`_state(s', f), [`FRAME_%{%}%`_instr(n, f'', instr'*{instr' <- `instr'*`})])) - -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [`FRAME_%{%}%`_instr(n, f', instr*{instr <- `instr*`})])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s', f), [`FRAME_%{%}%`_instr(n, f'', instr'*{instr' <- `instr'*`})])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 - rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) - -- if (a = |$exninst(z)|) - -- if (exn = {TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) - -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) - -- wf_exninst: `%`({TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 - rule `local.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_local(z, x, val), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:318.1-319.58 - rule `global.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_global(z, x, val), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 - rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 - rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) - -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 - rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if (ti = !($growtable($table(z, x), n, ref))) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:352.1-353.87 - rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:413.1-414.51 - rule `elem.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config($with_elem(z, x, []), [])) - -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_elem(z, x, []), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 - rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 - rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if (b*{b <- `b*`} = $nbytes_(nt, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 - rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 - rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 - rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 - rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 - rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + N) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 - rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if (N = $jsize(Jnn)) - -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- wf_uN: `%%`(N, `%`_uN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 - rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if (mi = !($growmem($mem(z, x), n))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:554.1-555.84 - rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:615.1-616.51 - rule `data.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config($with_data(z, x, []), [])) - -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_data(z, x, []), [])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:692.1-696.65 - rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) - -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (a = |$structinst(z)|) - -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 - rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 - rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, i!`%`_uN.0, !($packfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], val))), [])) - -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)])) - -- wf_config: `%`(`%;%`_config($with_struct(z, a, i!`%`_uN.0, !($packfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], val))), [])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:732.1-737.65 - rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) - -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 - rule `array.set-null`{z : state, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 - rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 - rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, !($proj_num__0(i))!`%`_uN.0, !($packfield_(zt, val))), [])) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_array(z, a, !($proj_num__0(i))!`%`_uN.0, !($packfield_(zt, val))), [])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -} - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:8.1-8.92 -relation Steps: `%~>*%`(config, config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:21.1-22.26 - rule refl{z : state, `instr*` : instr*}: - `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:24.1-27.44 - rule trans{z : state, `instr*` : instr*, z'' : state, `instr''*` : instr*, z' : state, `instr'*` : instr*}: - `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z'', instr''*{instr'' <- `instr''*`})) - -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) - -- Steps: `%~>*%`(`%;%`_config(z', instr'*{instr' <- `instr'*`}), `%;%`_config(z'', instr''*{instr'' <- `instr''*`})) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z'', instr''*{instr'' <- `instr''*`})) - -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) -} - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule _{z : state, `instr*` : instr*, z' : state, `val*` : val*}: - `%;%~>*%;%`(z, instr*{instr <- `instr*`}, z', val*{val <- `val*`}) - -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`})) - -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`})) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.1-7.63 -def $alloctypes(type*) : deftype* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:8.1-8.27 - def $alloctypes([]) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:9.1-13.24 - def $alloctypes{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN}(type'*{type' <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} - -- let{`deftype'*` : deftype*} deftype'*{deftype' <- `deftype'*`} = $alloctypes(type'*{type' <- `type'*`}) - -- let{rectype : rectype} TYPE_type(rectype) = type - -- if (deftype*{deftype <- `deftype*`} = $subst_all_deftypes($rolldt(x, rectype), (deftype' : deftype <: typeuse)*{deftype' <- `deftype'*`})) - -- if (x!`%`_uN.0 = |deftype'*{deftype' <- `deftype'*`}|) - -- wf_uN: `%%`(32, x) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) - -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_taginst: `%`({TYPE tagtype}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.1-20.102 -def $alloctags(store : store, tagtype*) : (store, tagaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:21.1-21.34 - def $alloctags{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:22.1-24.49 - def $alloctags{s : store, tagtype : typeuse, `tagtype'*` : tagtype*}(s, [tagtype] ++ tagtype'*{tagtype' <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) - -- let{ja : tagaddr, s_1 : store} (s_1, ja) = $alloctag(s, tagtype) - -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) - -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.1-31.122 -def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:32.1-32.42 - def $allocglobals{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:33.1-35.62 - def $allocglobals{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*}(s, [globaltype] ++ globaltype'*{globaltype' <- `globaltype'*`}, [val] ++ val'*{val' <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) - -- let{ga : globaladdr, s_1 : store} (s_1, ga) = $allocglobal(s, globaltype, val) - -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(store : store, memtype : memtype) : (store, memaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) - -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.1-42.102 -def $allocmems(store : store, memtype*) : (store, memaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:43.1-43.34 - def $allocmems{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:44.1-46.49 - def $allocmems{s : store, memtype : memtype, `memtype'*` : memtype*}(s, [memtype] ++ memtype'*{memtype' <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) - -- let{ma : memaddr, s_1 : store} (s_1, ma) = $allocmem(s, memtype) - -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) - -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.1-53.118 -def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:54.1-54.41 - def $alloctables{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:55.1-57.60 - def $alloctables{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*}(s, [tabletype] ++ tabletype'*{tabletype' <- `tabletype'*`}, [ref] ++ ref'*{ref' <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) - -- let{ta : tableaddr, s_1 : store} (s_1, ta) = $alloctable(s, tabletype, ref) - -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) - -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.1-64.133 -def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funcaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:65.1-65.45 - def $allocfuncs{s : store}(s, [], [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:66.1-68.71 - def $allocfuncs{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*}(s, [dt] ++ dt'*{dt' <- `dt'*`}, [funccode] ++ funccode'*{funccode' <- `funccode'*`}, [moduleinst] ++ moduleinst'*{moduleinst' <- `moduleinst'*`}) = (s_2, [fa] ++ fa'*{fa' <- `fa'*`}) - -- let{fa : funcaddr, s_1 : store} (s_1, fa) = $allocfunc(s, dt, funccode, moduleinst) - -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) - -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.1-75.118 -def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 - def $allocdatas{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'*{ok' <- `ok'*`}, [b*{b <- `b*`}] ++ b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b*{b <- `b*`}) - -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) - -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.1-86.117 -def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:87.1-87.40 - def $allocelems{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:88.1-90.55 - def $allocelems{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**}(s, [rt] ++ rt'*{rt' <- `rt'*`}, [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = (s_2, [ea] ++ ea'*{ea' <- `ea'*`}) - -- let{ea : elemaddr, s_1 : store} (s_1, ea) = $allocelem(s, rt, ref*{ref <- `ref*`}) - -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexport(moduleinst : moduleinst, export : export) : exportinst - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexports(moduleinst : moduleinst, export*) : exportinst* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (tag*{tag <- `tag*`} = TAG_tag(tagtype)*{tagtype <- `tagtype*`}) - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (mem*{mem <- `mem*`} = MEMORY_mem(memtype)*{memtype <- `memtype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (func*{func <- `func*`} = FUNC_func(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`}) - -- let{`aa_I*` : tagaddr*} aa_I*{aa_I <- `aa_I*`} = $tagsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ga_I*` : globaladdr*} ga_I*{ga_I <- `ga_I*`} = $globalsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ma_I*` : memaddr*} ma_I*{ma_I <- `ma_I*`} = $memsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ta_I*` : tableaddr*} ta_I*{ta_I <- `ta_I*`} = $tablesxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`fa_I*` : funcaddr*} fa_I*{fa_I <- `fa_I*`} = $funcsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $alloctypes(type*{type <- `type*`}) - -- let{`fa*` : nat*} fa*{fa <- `fa*`} = (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){} - -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa*{aa <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tagtype <- `tagtype*`}) - -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga*{ga <- `ga*`}) = $allocglobals(s_1, $subst_all_globaltype(globaltype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{globaltype <- `globaltype*`}, val_G*{val_G <- `val_G*`}) - -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma*{ma <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{memtype <- `memtype*`}) - -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta*{ta <- `ta*`}) = $alloctables(s_3, $subst_all_tabletype(tabletype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tabletype <- `tabletype*`}, ref_T*{ref_T <- `ref_T*`}) - -- let{s_5 : store, `da*` : dataaddr*} (s_5, da*{da <- `da*`}) = $allocdatas(s_4, OK_datatype^|data*{data <- `data*`}|{}, byte*{byte <- `byte*`}*{`byte*` <- `byte**`}) - -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea*{ea <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{elemtype <- `elemtype*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[x!`%`_uN.0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) - -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) - -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_mem: `%`(MEMORY_mem(memtype)))*{memtype <- `memtype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr_F)))*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`} - -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) - -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $rundata_(dataidx : dataidx, data : data) : instr* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $runelem_(elemidx : elemidx, elem : elem) : instr* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.1-160.92 -def $evalexprs(state : state, expr*) : (state, ref*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:161.1-161.34 - def $evalexprs{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:162.1-165.46 - def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) - -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) - -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) - -- wf_state: `%`(z') -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 -def $evalexprss(state : state, expr**) : (state, ref**) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 - def $evalexprss{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:169.1-172.49 - def $evalexprss{z : state, `expr*` : expr*, `expr'**` : expr**}(z, [expr*{expr <- `expr*`}] ++ expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) - -- let{`ref*` : ref*, z' : state} (z', ref*{ref <- `ref*`}) = $evalexprs(z, expr*{expr <- `expr*`}) - -- let{z'' : state, `ref'**` : ref**} (z'', ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = $evalexprss(z', expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 -def $evalglobals(state : state, globaltype*, expr*) : (state, val*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 - def $evalglobals{z : state}(z, [], []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:176.1-181.82 - def $evalglobals{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state}(z, [gt] ++ gt'*{gt' <- `gt'*`}, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [val] ++ val'*{val' <- `val'*`}) - -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) - -- let{s : store, f : frame} `%;%`_state(s, f) = z' - -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) - -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) - -- wf_state: `%`(z') - -- wf_state: `%`(`%;%`_state(s, f)) - -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) -} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $instantiate(store : store, module : module, externaddr*) : config - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr*{externaddr <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) - -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- (Externaddr_ok: `%|-%:%`(s, externaddr, xt_I))*{externaddr <- `externaddr*`, xt_I <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`}) - -- if (start?{start <- `start?`} = START_start(x)?{x <- `x?`}) - -- if (moduleinst_0 = {TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) - -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- let{z' : state, `val_G*` : val*} (z', val_G*{val_G <- `val_G*`}) = $evalglobals(z, globaltype*{globaltype <- `globaltype*`}, expr_G*{expr_G <- `expr_G*`}) - -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T*{ref_T <- `ref_T*`}) = $evalexprs(z', expr_T*{expr_T <- `expr_T*`}) - -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = $evalexprss(z'', expr_E*{expr_E <- `expr_E*`}*{`expr_E*` <- `expr_E**`}) - -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' - -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- let{`instr_D*` : instr*} instr_D*{instr_D <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D), data*{data <- `data*`}[i_D])^(i_D<|data*{data <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) - -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} - -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`} - -- (wf_start: `%`(START_start(x)))?{x <- `x?`} - -- wf_moduleinst: `%`({TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) - -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- wf_state: `%`(`%;%`_state(s''', f)) - -- (wf_uN: `%%`(32, `%`_uN(i_D)))^(i_D<|data*{data <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} - -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} - -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -syntax castop = (null?, null?) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -syntax memidxop = (memidx, memarg) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -syntax startopt = start* - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -syntax code = (local*, expr) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -syntax nopt = u32* - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -def $ieee_(N : N, rat : rat) : fNmag - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -syntax idctxt = -{ - TYPES name?*, - TAGS name?*, - GLOBALS name?*, - MEMS name?*, - TABLES name?*, - FUNCS name?*, - DATAS name?*, - ELEMS name?*, - LOCALS name?*, - LABELS name?*, - FIELDS name?**, - TYPEDEFS deftype?* -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -relation wf_idctxt: `%`(idctxt) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - rule idctxt_case_{var_0 : name?*, var_1 : name?*, var_2 : name?*, var_3 : name?*, var_4 : name?*, var_5 : name?*, var_6 : name?*, var_7 : name?*, var_8 : name?*, var_9 : name?*, var_10 : name?**, var_11 : deftype?*}: - `%`({TYPES var_0, TAGS var_1, GLOBALS var_2, MEMS var_3, TABLES var_4, FUNCS var_5, DATAS var_6, ELEMS var_7, LOCALS var_8, LABELS var_9, FIELDS var_10, TYPEDEFS var_11}) - -- (wf_name: `%`(var_0))?{var_0 <- var_0}*{var_0 <- var_0} - -- (wf_name: `%`(var_1))?{var_1 <- var_1}*{var_1 <- var_1} - -- (wf_name: `%`(var_2))?{var_2 <- var_2}*{var_2 <- var_2} - -- (wf_name: `%`(var_3))?{var_3 <- var_3}*{var_3 <- var_3} - -- (wf_name: `%`(var_4))?{var_4 <- var_4}*{var_4 <- var_4} - -- (wf_name: `%`(var_5))?{var_5 <- var_5}*{var_5 <- var_5} - -- (wf_name: `%`(var_6))?{var_6 <- var_6}*{var_6 <- var_6} - -- (wf_name: `%`(var_7))?{var_7 <- var_7}*{var_7 <- var_7} - -- (wf_name: `%`(var_8))?{var_8 <- var_8}*{var_8 <- var_8} - -- (wf_name: `%`(var_9))?{var_9 <- var_9}*{var_9 <- var_9} - -- (wf_name: `%`(var_10))?{var_10 <- var_10}*{var_10 <- var_10}*{var_10 <- var_10} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -syntax I = idctxt - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.1-154.56 -def $concat_idctxt(idctxt*) : idctxt - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 - def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 - def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -relation Idctxt_ok: `|-%:OK`(idctxt) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - rule _{I : I, `field**` : char**}: - `|-%:OK`(I) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.TYPES_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.TAGS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.GLOBALS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.MEMS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.TABLES_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.FUNCS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.DATAS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.ELEMS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.LOCALS_I)) - -- if $disjoint_(syntax name, $concatopt_(syntax name, I.LABELS_I)) - -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} - -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) - -- wf_idctxt: `%`(I) - -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $dots : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -syntax decl = - | TYPE(rectype : rectype) - | IMPORT(name : name, name : name, externtype : externtype) - | TAG(tagtype : tagtype) - | GLOBAL(globaltype : globaltype, expr : expr) - | MEMORY(memtype : memtype) - | TABLE(tabletype : tabletype, expr : expr) - | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) - | DATA(`byte*` : byte*, datamode : datamode) - | ELEM(reftype : reftype, `expr*` : expr*, elemmode : elemmode) - | START(funcidx : funcidx) - | EXPORT(name : name, externidx : externidx) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -relation wf_decl: `%`(decl) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_0{rectype : rectype}: - `%`(TYPE_decl(rectype)) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_1{name : name, name_0 : name, externtype : externtype}: - `%`(IMPORT_decl(name, name_0, externtype)) - -- wf_name: `%`(name) - -- wf_name: `%`(name_0) - -- wf_externtype: `%`(externtype) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_2{tagtype : tagtype}: - `%`(TAG_decl(tagtype)) - -- wf_typeuse: `%`(tagtype) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_3{globaltype : globaltype, expr : expr}: - `%`(GLOBAL_decl(globaltype, expr)) - -- wf_globaltype: `%`(globaltype) - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_4{memtype : memtype}: - `%`(MEMORY_decl(memtype)) - -- wf_memtype: `%`(memtype) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_5{tabletype : tabletype, expr : expr}: - `%`(TABLE_decl(tabletype, expr)) - -- wf_tabletype: `%`(tabletype) - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_6{typeidx : typeidx, `local*` : local*, expr : expr}: - `%`(FUNC_decl(typeidx, `local*`, expr)) - -- wf_uN: `%%`(32, typeidx) - -- (wf_local: `%`(local))*{local <- `local*`} - -- (wf_instr: `%`(expr))*{expr <- expr} - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_7{`byte*` : byte*, datamode : datamode}: - `%`(DATA_decl(`byte*`, datamode)) - -- (wf_byte: `%`(byte))*{byte <- `byte*`} - -- wf_datamode: `%`(datamode) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_8{reftype : reftype, `expr*` : expr*, elemmode : elemmode}: - `%`(ELEM_decl(reftype, `expr*`, elemmode)) - -- wf_reftype: `%`(reftype) - -- (wf_instr: `%`(expr))*{expr <- expr}*{expr <- `expr*`} - -- wf_elemmode: `%`(elemmode) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_9{funcidx : funcidx}: - `%`(START_decl(funcidx)) - -- wf_uN: `%%`(32, funcidx) - - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule decl_case_10{name : name, externidx : externidx}: - `%`(EXPORT_decl(name, externidx)) - -- wf_name: `%`(name) - -- wf_externidx: `%`(externidx) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.1-258.76 -def $typesd(decl*) : type* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:270.1-270.23 - def $typesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:271.1-271.48 - def $typesd{type : type, `decl'*` : decl*}([(type : type <: decl)] ++ decl'*{decl' <- `decl'*`}) = [type] ++ $typesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:272.1-272.57 - def $typesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $typesd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.1-259.78 -def $importsd(decl*) : import* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:274.1-274.25 - def $importsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:275.1-275.56 - def $importsd{import : import, `decl'*` : decl*}([(import : import <: decl)] ++ decl'*{decl' <- `decl'*`}) = [import] ++ $importsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:276.1-276.61 - def $importsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $importsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 -def $tagsd(decl*) : tag* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 - def $tagsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:279.1-279.44 - def $tagsd{tag : tag, `decl'*` : decl*}([(tag : tag <: decl)] ++ decl'*{decl' <- `decl'*`}) = [tag] ++ $tagsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:280.1-280.55 - def $tagsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tagsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 -def $globalsd(decl*) : global* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 - def $globalsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:283.1-283.56 - def $globalsd{global : global, `decl'*` : decl*}([(global : global <: decl)] ++ decl'*{decl' <- `decl'*`}) = [global] ++ $globalsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:284.1-284.61 - def $globalsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $globalsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 -def $memsd(decl*) : mem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 - def $memsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:287.1-287.44 - def $memsd{mem : mem, `decl'*` : decl*}([(mem : mem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [mem] ++ $memsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:288.1-288.55 - def $memsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $memsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 -def $tablesd(decl*) : table* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 - def $tablesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:291.1-291.52 - def $tablesd{table : table, `decl'*` : decl*}([(table : table <: decl)] ++ decl'*{decl' <- `decl'*`}) = [table] ++ $tablesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:292.1-292.59 - def $tablesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tablesd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 -def $funcsd(decl*) : func* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 - def $funcsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:295.1-295.48 - def $funcsd{func : func, `decl'*` : decl*}([(func : func <: decl)] ++ decl'*{decl' <- `decl'*`}) = [func] ++ $funcsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:296.1-296.57 - def $funcsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $funcsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 -def $datasd(decl*) : data* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 - def $datasd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:299.1-299.48 - def $datasd{data : data, `decl'*` : decl*}([(data : data <: decl)] ++ decl'*{decl' <- `decl'*`}) = [data] ++ $datasd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:300.1-300.57 - def $datasd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $datasd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 -def $elemsd(decl*) : elem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 - def $elemsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:303.1-303.48 - def $elemsd{elem : elem, `decl'*` : decl*}([(elem : elem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [elem] ++ $elemsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:304.1-304.57 - def $elemsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $elemsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 -def $startsd(decl*) : start* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 - def $startsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:307.1-307.52 - def $startsd{start : start, `decl'*` : decl*}([(start : start <: decl)] ++ decl'*{decl' <- `decl'*`}) = [start] ++ $startsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:308.1-308.59 - def $startsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $startsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 -def $exportsd(decl*) : export* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 - def $exportsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:311.1-311.56 - def $exportsd{export : export, `decl'*` : decl*}([(export : export <: decl)] ++ decl'*{decl' <- `decl'*`}) = [export] ++ $exportsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:312.1-312.61 - def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) -} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(decl*) : bool - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl*` : decl*}(decl*{decl <- `decl*`}) = true - -- if ($importsd(decl*{decl <- `decl*`}) = []) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl_1*` : decl*, import : import, `decl_2*` : decl*}(decl_1*{decl_1 <- `decl_1*`} ++ [(import : import <: decl)] ++ decl_2*{decl_2 <- `decl_2*`}) = (((((($importsd(decl_1*{decl_1 <- `decl_1*`}) = []) /\ ($tagsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($globalsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($memsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($tablesd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($funcsd(decl_1*{decl_1 <- `decl_1*`}) = [])) - -;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec -relation Context_ok: `|-%:OK`(context) - ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec - rule _{C : context, n : n, `dt*` : deftype*, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt_F*` : deftype*, `ok*` : datatype*, `et*` : elemtype*, `lct*` : localtype*, `rt*` : reftype*, `rt'?` : reftype?, `x*` : idx*, m : m, `st*` : subtype*, C_0 : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `|-%:OK`(C) - -- if (C = {TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) - -- if (C_0 = {TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (Deftype_ok: `%|-%:OK`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} - -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} - -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt : reftype <: valtype)])))*{rt <- `rt*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt' : reftype <: valtype)])))?{rt' <- `rt'?`} - -- (if (x!`%`_uN.0 < |dt_F*{dt_F <- `dt_F*`}|))*{x <- `x*`} - -- wf_context: `%`(C) - -- wf_context: `%`(C_0) - -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) - -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Localval_ok: `%|-%:%`(store, val?, localtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule set{s : store, val : val, t : valtype}: - `%|-%:%`(s, ?(val), `%%`_localtype(SET_init, t)) - -- Val_ok: `%|-%:%`(s, val, t) - -- wf_store: `%`(s) - -- wf_val: `%`(val) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule unset{s : store}: - `%|-%:%`(s, ?(), `%%`_localtype(UNSET_init, BOT_valtype)) - -- wf_store: `%`(s) - -- wf_localtype: `%`(`%%`_localtype(UNSET_init, BOT_valtype)) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Datainst_ok: `%|-%:%`(store, datainst, datatype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, `b*` : byte*}: - `%|-%:%`(s, {BYTES b*{b <- `b*`}}, OK_datatype) - -- wf_store: `%`(s) - -- wf_datainst: `%`({BYTES b*{b <- `b*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Eleminst_ok: `%|-%:%`(store, eleminst, elemtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, rt : reftype, `ref*` : ref*}: - `%|-%:%`(s, {TYPE rt, REFS ref*{ref <- `ref*`}}, rt) - -- Reftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt) - -- (Ref_ok: `%|-%:%`(s, ref, rt))*{ref <- `ref*`} - -- wf_store: `%`(s) - -- wf_eleminst: `%`({TYPE rt, REFS ref*{ref <- `ref*`}}) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Exportinst_ok: `%|-%:OK`(store, exportinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, nm : name, xa : externaddr, xt : externtype}: - `%|-%:OK`(s, {NAME nm, ADDR xa}) - -- Externaddr_ok: `%|-%:%`(s, xa, xt) - -- wf_store: `%`(s) - -- wf_externtype: `%`(xt) - -- wf_exportinst: `%`({NAME nm, ADDR xa}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, `deftype*` : deftype*, `tagaddr*` : tagaddr*, `globaladdr*` : globaladdr*, `memaddr*` : memaddr*, `tableaddr*` : tableaddr*, `funcaddr*` : funcaddr*, `dataaddr*` : dataaddr*, `elemaddr*` : elemaddr*, `exportinst*` : exportinst*, `tagtype*` : tagtype*, `globaltype*` : globaltype*, `memtype*` : memtype*, `tabletype*` : tabletype*, `deftype_F*` : deftype*, `datatype*` : datatype*, `elemtype*` : elemtype*, `subtype*` : subtype*}: - `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) - -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} - -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} - -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} - -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} - -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} - -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} - -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} - -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} - -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} - -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) - -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} - -- wf_store: `%`(s) - -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) - -- wf_context: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (wf_externtype: `%`(TAG_externtype(tagtype)))*{tagtype <- `tagtype*`} - -- (wf_externtype: `%`(GLOBAL_externtype(globaltype)))*{globaltype <- `globaltype*`} - -- (wf_externtype: `%`(FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`} - -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} - -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Frame_ok: `%|-%:%`(store, frame, context) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, `val?*` : val?*, moduleinst : moduleinst, C : context, `lct*` : localtype*}: - `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) - -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_frame: `%`({LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:3.1-4.36 -relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:10.1-12.46 - rule plain{s : store, C : context, instr : instr, `t_1*` : valtype*, `x*` : idx*, `t_2*` : valtype*}: - `%;%|-%:%`(s, C, instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instr_ok: `%|-%:%`(C, instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instr: `%`(instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:14.1-16.27 - rule ref{s : store, C : context, ref : ref, rt : reftype}: - `%;%|-%:%`(s, C, (ref : ref <: instr), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- Ref_ok: `%|-%:%`(s, ref, rt) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_ref: `%`(ref) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:18.1-21.68 - rule label{s : store, C : context, n : n, `instr'*` : instr*, `instr*` : instr*, `t*` : valtype*, `t'*` : valtype*, `x'*` : idx*, `x*` : idx*}: - `%;%|-%:%`(s, C, `LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr'*{instr' <- `instr'*`}, `%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) - -- Instrs_ok2: `%;%|-%:%`(s, {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []} +++ C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 - rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: - `%;%|-%:%`(s, C, `FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) - -- Frame_ok: `%|-%:%`(s, f, C') - -- Expr_ok2: `%;%|-%:%`(s, C', instr*{instr <- `instr*`}, `%`_resulttype(t^n{t <- `t*`})) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_context: `%`(C') - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 - rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: - `%;%|-%:%`(s, C, `HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Catch_ok: `%|-%:OK`(C, catch))*{catch <- `catch*`} - -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:33.1-35.42 - rule trap{s : store, C : context, `t_1*` : valtype*, `t_2*` : valtype*}: - `%;%|-%:%`(s, C, TRAP_instr, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instr: `%`(TRAP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:5.1-6.36 -relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:38.1-39.27 - rule empty{s : store, C : context}: - `%;%|-%:%`(s, C, [], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:41.1-45.86 - rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: - `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if (C.LOCALS_context[x_1!`%`_uN.0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_instr: `%`(instr_1) - -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 - rule sub{s : store, C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: - `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, it') - -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, it) - -- Instrtype_sub: `%|-%<:%`(C, it, it') - -- Instrtype_ok: `%|-%:OK`(C, it') - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(it') - -- wf_instrtype: `%`(it) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:54.1-57.33 - rule frame{s : store, C : context, `instr*` : instr*, `t*` : valtype*, `t_1*` : valtype*, `x*` : idx*, `t_2*` : valtype*}: - `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`} ++ t_2*{t_2 <- `t_2*`}))) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t*{t <- `t*`})) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`} ++ t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:7.1-8.36 -relation Expr_ok2: `%;%|-%:%`(store, context, expr, resulttype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:60.1-62.44 - rule _{s : store, C : context, `instr*` : instr*, `t*` : valtype*}: - `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%`_resulttype(t*{t <- `t*`})) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) -} - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Taginst_ok: `%|-%:%`(store, taginst, tagtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, jt : tagtype}: - `%|-%:%`(s, {TYPE jt}, jt) - -- Tagtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, jt) - -- wf_store: `%`(s) - -- wf_taginst: `%`({TYPE jt}) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Globalinst_ok: `%|-%:%`(store, globalinst, globaltype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, `mut?` : mut?, t : valtype, val : val}: - `%|-%:%`(s, {TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val}, `%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- Globaltype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- Val_ok: `%|-%:%`(s, val, t) - -- wf_store: `%`(s) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val}) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Meminst_ok: `%|-%:%`(store, meminst, memtype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, at : addrtype, n : n, m : m, `b*` : byte*}: - `%|-%:%`(s, {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))), BYTES b*{b <- `b*`}}, `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))))) - -- Memtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))))) - -- if (|b*{b <- `b*`}| = (n * (64 * $Ki))) - -- wf_store: `%`(s) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))), BYTES b*{b <- `b*`}}) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Tableinst_ok: `%|-%:%`(store, tableinst, tabletype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, at : addrtype, n : n, m : m, rt : reftype, `ref*` : ref*}: - `%|-%:%`(s, {TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt), REFS ref*{ref <- `ref*`}}, `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt)) - -- Tabletype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt)) - -- if (|ref*{ref <- `ref*`}| = n) - -- (Ref_ok: `%|-%:%`(s, ref, rt))*{ref <- `ref*`} - -- wf_store: `%`(s) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt), REFS ref*{ref <- `ref*`}}) - -- wf_tabletype: `%`(`%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt)) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Funcinst_ok: `%|-%:%`(store, funcinst, deftype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, dt : deftype, moduleinst : moduleinst, func : func, C : context, dt' : deftype}: - `%|-%:%`(s, {TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}, dt) - -- Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt) - -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- Func_ok: `%|-%:%`(C, func, dt') - -- Deftype_sub: `%|-%<:%`(C, dt', dt) - -- wf_store: `%`(s) - -- wf_context: `%`(C) - -- wf_funcinst: `%`({TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Structinst_ok: `%|-%:OK`(store, structinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: - `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} - -- wf_store: `%`(s) - -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Arrayinst_ok: `%|-%:OK`(store, arrayinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?` : mut?, zt : storagetype}: - `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`} - -- wf_store: `%`(s) - -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Exninst_ok: `%|-%:OK`(store, exninst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: - `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) - -- if ((dt : deftype <: typeuse) = s.TAGS_store[ta].TYPE_taginst) - -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} - -- wf_store: `%`(s) - -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:208.1-209.50 -relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:222.1-225.35 - rule trans{fv_1 : fieldval, s : store, fv_2 : fieldval, fv' : fieldval}: - `%>>_%%`(fv_1, s, fv_2) - -- ImmutReachable: `%>>_%%`(fv_1, s, fv') - -- ImmutReachable: `%>>_%%`(fv', s, fv_2) - -- wf_fieldval: `%`(fv_1) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(fv_2) - -- wf_fieldval: `%`(fv') - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 - rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: - `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 - rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: - `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 - rule `ref.exn`{a : addr, s : store, i : nat}: - `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, (s.EXNS_store[a].FIELDS_exninst[i] : val <: fieldval)) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) - - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:239.1-240.28 - rule `ref.extern`{ref : ref, s : store}: - `%>>_%%`(`REF.EXTERN`_fieldval(ref), s, (ref : ref <: fieldval)) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.EXTERN`_fieldval(ref)) -} - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -def $NotImmutReachable(fieldval : fieldval, store : store, fieldval : fieldval) : bool - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = false - -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = true - -- otherwise - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation NotImmutReachable: `~%>>_%%`(fieldval, store, fieldval) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{fv_1 : fieldval, s : store, fv_2 : fieldval}: - `~%>>_%%`(fv_1, s, fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) - -- wf_fieldval: `%`(fv_1) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(fv_2) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Store_ok: `|-%:OK`(store) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: - `|-%:OK`(s) - -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} - -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} - -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} - -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} - -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} - -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} - -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} - -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} - -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} - -- (Exninst_ok: `%|-%:OK`(s, exninst))*{exninst <- `exninst*`} - -- (NotImmutReachable: `~%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, `REF.STRUCT_ADDR`_fieldval(a)))^(a<|structinst*{structinst <- `structinst*`}|){} - -- (NotImmutReachable: `~%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, `REF.ARRAY_ADDR`_fieldval(a)))^(a<|arrayinst*{arrayinst <- `arrayinst*`}|){} - -- (NotImmutReachable: `~%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, `REF.EXN_ADDR`_fieldval(a)))^(a<|exninst*{exninst <- `exninst*`}|){} - -- if (s = {TAGS taginst*{taginst <- `taginst*`}, GLOBALS globalinst*{globalinst <- `globalinst*`}, MEMS meminst*{meminst <- `meminst*`}, TABLES tableinst*{tableinst <- `tableinst*`}, FUNCS funcinst*{funcinst <- `funcinst*`}, DATAS datainst*{datainst <- `datainst*`}, ELEMS eleminst*{eleminst <- `eleminst*`}, STRUCTS structinst*{structinst <- `structinst*`}, ARRAYS arrayinst*{arrayinst <- `arrayinst*`}, EXNS exninst*{exninst <- `exninst*`}}) - -- wf_store: `%`(s) - -- (wf_typeuse: `%`(tagtype))*{tagtype <- `tagtype*`} - -- (wf_globaltype: `%`(globaltype))*{globaltype <- `globaltype*`} - -- (wf_memtype: `%`(memtype))*{memtype <- `memtype*`} - -- (wf_tabletype: `%`(tabletype))*{tabletype <- `tabletype*`} - -- (wf_reftype: `%`(elemtype))*{elemtype <- `elemtype*`} - -- (wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)))^(a<|structinst*{structinst <- `structinst*`}|){} - -- (wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)))^(a<|arrayinst*{arrayinst <- `arrayinst*`}|){} - -- (wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)))^(a<|exninst*{exninst <- `exninst*`}|){} - -- wf_store: `%`({TAGS taginst*{taginst <- `taginst*`}, GLOBALS globalinst*{globalinst <- `globalinst*`}, MEMS meminst*{meminst <- `meminst*`}, TABLES tableinst*{tableinst <- `tableinst*`}, FUNCS funcinst*{funcinst <- `funcinst*`}, DATAS datainst*{datainst <- `datainst*`}, ELEMS eleminst*{eleminst <- `eleminst*`}, STRUCTS structinst*{structinst <- `structinst*`}, ARRAYS arrayinst*{arrayinst <- `arrayinst*`}, EXNS exninst*{exninst <- `exninst*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_taginst: `%<=%`(taginst, taginst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{jt : tagtype}: - `%<=%`({TYPE jt}, {TYPE jt}) - -- wf_taginst: `%`({TYPE jt}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_globalinst: `%<=%`(globalinst, globalinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{`mut?` : mut?, t : valtype, val : val, val' : val}: - `%<=%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val}, {TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val'}) - -- if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (val = val')) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val}) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val'}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_meminst: `%<=%`(meminst, meminst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{at : addrtype, n : n, m : m, `b*` : byte*, n' : n, `b'*` : byte*}: - `%<=%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))), BYTES b*{b <- `b*`}}, {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(m)))), BYTES b'*{b' <- `b'*`}}) - -- if (n <= n') - -- if (|b*{b <- `b*`}| <= |b'*{b' <- `b'*`}|) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))), BYTES b*{b <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(m)))), BYTES b'*{b' <- `b'*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_tableinst: `%<=%`(tableinst, tableinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{at : addrtype, n : n, m : m, rt : reftype, `ref*` : ref*, n' : n, `ref'*` : ref*}: - `%<=%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt), REFS ref*{ref <- `ref*`}}, {TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(m))), rt), REFS ref'*{ref' <- `ref'*`}}) - -- if (n <= n') - -- if (|ref*{ref <- `ref*`}| <= |ref'*{ref' <- `ref'*`}|) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))), rt), REFS ref*{ref <- `ref*`}}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(m))), rt), REFS ref'*{ref' <- `ref'*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_funcinst: `%<=%`(funcinst, funcinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{dt : deftype, mm : moduleinst, fc : funccode}: - `%<=%`({TYPE dt, MODULE mm, CODE fc}, {TYPE dt, MODULE mm, CODE fc}) - -- wf_funcinst: `%`({TYPE dt, MODULE mm, CODE fc}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_datainst: `%<=%`(datainst, datainst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{`b*` : byte*, `b'*` : byte*}: - `%<=%`({BYTES b*{b <- `b*`}}, {BYTES b'*{b' <- `b'*`}}) - -- if ((b*{b <- `b*`} = b'*{b' <- `b'*`}) \/ (b'*{b' <- `b'*`} = [])) - -- wf_datainst: `%`({BYTES b*{b <- `b*`}}) - -- wf_datainst: `%`({BYTES b'*{b' <- `b'*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_eleminst: `%<=%`(eleminst, eleminst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{rt : reftype, `ref*` : ref*, `ref'*` : ref*}: - `%<=%`({TYPE rt, REFS ref*{ref <- `ref*`}}, {TYPE rt, REFS ref'*{ref' <- `ref'*`}}) - -- if ((ref*{ref <- `ref*`} = ref'*{ref' <- `ref'*`}) \/ (ref'*{ref' <- `ref'*`} = [])) - -- wf_eleminst: `%`({TYPE rt, REFS ref*{ref <- `ref*`}}) - -- wf_eleminst: `%`({TYPE rt, REFS ref'*{ref' <- `ref'*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_structinst: `%<=%`(structinst, structinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: - `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) - -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} - -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?` : mut?, zt : storagetype}: - `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) - -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} - -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) - -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_exninst: `%<=%`(exninst, exninst) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{ta : tagaddr, `val*` : val*}: - `%<=%`({TAG ta, FIELDS val*{val <- `val*`}}, {TAG ta, FIELDS val*{val <- `val*`}}) - -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Extend_store: `%<=%`(store, store) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, s' : store}: - `%<=%`(s, s') - -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} - -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} - -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} - -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} - -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} - -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} - -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} - -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} - -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} - -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} - -- wf_store: `%`(s) - -- wf_store: `%`(s') - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation State_ok: `|-%:%`(state, context) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, f : frame, C : context}: - `|-%:%`(`%;%`_state(s, f), C) - -- Store_ok: `|-%:OK`(s) - -- Frame_ok: `%|-%:%`(s, f, C) - -- wf_context: `%`(C) - -- wf_state: `%`(`%;%`_state(s, f)) - -;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -relation Config_ok: `|-%:%`(config, resulttype) - ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{s : store, f : frame, `instr*` : instr*, `t*` : valtype*, C : context}: - `|-%:%`(`%;%`_config(`%;%`_state(s, f), instr*{instr <- `instr*`}), `%`_resulttype(t*{t <- `t*`})) - -- State_ok: `|-%:%`(`%;%`_state(s, f), C) - -- Expr_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%`_resulttype(t*{t <- `t*`})) - -- (wf_valtype: `%`(t))*{t <- `t*`} - -- wf_context: `%`(C) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), instr*{instr <- `instr*`})) - -- wf_state: `%`(`%;%`_state(s, f)) - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax A = nat - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax B = nat - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax sym = - | _FIRST(A_1 : A) - | _DOTS - | _LAST(A_n : A) - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax symsplit = - | _FIRST(A_1 : A) - | _LAST(A_2 : A) - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax recorddots = () - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax record = -{ - FIELD_1 A, - FIELD_2 A, - `...` recorddots -} - -;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec -syntax pth = - | PTHSYNTAX - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec -syntax T = nat - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec -relation NotationTypingPremise: `%`(nat) - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec -relation NotationTypingPremisedots: `...` - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec -relation NotationTypingScheme: `%`(nat) - ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec - rule _{conclusion : nat, premise_1 : nat, premise_2 : nat, premise_n : nat}: - `%`(conclusion) - -- NotationTypingPremise: `%`(premise_1) - -- NotationTypingPremise: `%`(premise_2) - -- NotationTypingPremisedots: `...` - -- NotationTypingPremise: `%`(premise_n) - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec -rec { - -;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:20.1-20.83 -relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) - ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:22.1-23.38 - rule `i32.add`{C : context}: - `%|-%:%`(C, [BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn))], `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([I32_valtype]))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([I32_valtype]))) - - ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 - rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: - `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(mut), t)) - -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_globaltype: `%`(`%%`_globaltype(?(mut), t)) - - ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:29.1-32.78 - rule block{C : context, blocktype : blocktype, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%:%`(C, [BLOCK_instr(blocktype, instr*{instr <- `instr*`})], `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Blocktype_ok: `%|-%:%`(C, blocktype, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- NotationTypingInstrScheme: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []} +++ C, instr*{instr <- `instr*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`(C) - -- wf_instr: `%`(BLOCK_instr(blocktype, instr*{instr <- `instr*`})) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(), REFS [], RECS []}) -} - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -relation NotationReduct: `~>%`(instr*) - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec - rule 2{q_1 : num_, q_4 : num_, q_3 : num_}: - `~>%`([CONST_instr(F64_numtype, q_1) CONST_instr(F64_numtype, q_4) CONST_instr(F64_numtype, q_3) BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn)) BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn))]) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_1)) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_4)) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_3)) - -- wf_instr: `%`(BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn))) - -- wf_instr: `%`(BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn))) - - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec - rule 3{q_1 : num_, q_5 : num_}: - `~>%`([CONST_instr(F64_numtype, q_1) CONST_instr(F64_numtype, q_5) BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn))]) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_1)) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_5)) - -- wf_instr: `%`(BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn))) - - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec - rule 4{q_6 : num_}: - `~>%`([CONST_instr(F64_numtype, q_6)]) - -- wf_instr: `%`(CONST_instr(F64_numtype, q_6)) - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -def $instrdots : instr* - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -syntax label = - | `LABEL_%{%}`(n : n, `instr*` : instr*) - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -relation wf_label: `%`(label) - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec - rule label_case_0{n : n, `instr*` : instr*}: - `%`(`LABEL_%{%}`_label(n, `instr*`)) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -syntax callframe = - | `FRAME_%{%}`(n : n, frame : frame) - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -relation wf_callframe: `%`(callframe) - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec - rule callframe_case_0{n : n, frame : frame}: - `%`(`FRAME_%{%}`_callframe(n, frame)) - -- wf_frame: `%`(frame) - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -rec { - -;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.1-32.117 -def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:33.1-33.57 - def $allocXs{syntax X, syntax Y, s : store}(syntax X, syntax Y, s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:34.1-36.65 - def $allocXs{syntax X, syntax Y, s : store, X : X, `X'*` : X*, Y : Y, `Y'*` : Y*}(syntax X, syntax Y, s, [X] ++ X'*{X' <- `X'*`}, [Y] ++ Y'*{Y' <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) - -- let{a : addr, s_1 : store} (s_1, a) = $allocX(syntax X, syntax Y, s, X, Y) - -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) -} - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -syntax symdots = - | `%`(i : nat) - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -relation wf_symdots: `%`(symdots) - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - rule symdots_case_0{i : nat}: - `%`(`%`_symdots(i)) - -- if (i = 0) - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -def $var(syntax X) : nat - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - def $var{syntax X}(syntax X) = 0 - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -syntax abbreviated = () - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -syntax expanded = () - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -syntax syntax = () - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bbyte : byte - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : nat} ``:(0x00 | ... | 0xFF) => `%`_byte(``) - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:9.1-11.82 -grammar BuN(N : N) : uN - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:10.5-10.83 - prod{n : n} `%`_byte(n):Bbyte => `%`_uN(n) - -- if ((n < (2 ^ 7)) /\ (n < (2 ^ N))) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:11.5-11.82 - prod{m : m, n : n} {{`%`_byte(n):Bbyte} {`%`_uN(m):BuN((((N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_uN((((2 ^ 7) * m) + (((n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat))) - -- if ((n >= (2 ^ 7)) /\ (N > 7)) -} - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:13.1-16.82 -grammar BsN(N : N) : sN - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:14.5-14.87 - prod{n : n} `%`_byte(n):Bbyte => `%`_sN((n : nat <:> int)) - -- if ((n < (2 ^ 6)) /\ (n < (2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:15.5-15.101 - prod{n : n} `%`_byte(n):Bbyte => `%`_sN(((n : nat <:> int) - ((2 ^ 7) : nat <:> int))) - -- if ((((2 ^ 6) <= n) /\ (n < (2 ^ 7))) /\ ((n : nat <:> int) >= (((2 ^ 7) : nat <:> int) - ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)))) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:16.5-16.82 - prod{i : sN, n : n} {{`%`_byte(n):Bbyte} {i:BsN((((N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_sN(((((2 ^ 7) * (i!`%`_sN.0 : int <:> nat)) + (((n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat)) : nat <:> int)) - -- if ((n >= (2 ^ 7)) /\ (N > 7)) -} - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar BiN(N : N) : iN - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{i : sN} i:BsN(N) => `%`_iN($inv_signed_(N, i!`%`_sN.0)) - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar BfN(N : N) : fN - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`b*` : byte*} b*{b <- `b*`}:Bbyte^(((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat){} => $inv_fbytes_(N, b*{b <- `b*`}) - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bu32 : u32 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : uN} ``:BuN(32) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bu64 : u64 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : uN} ``:BuN(64) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bs33 : s33 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : sN} ``:BsN(33) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bi32 : i32 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : uN} ``:BuN(32) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bi64 : i64 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : uN} ``:BuN(64) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bf32 : f32 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : fN} ``:BfN(32) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bf64 : f64 - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : fN} ``:BfN(64) => `` - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Blist(syntax el, grammar BX : el) : el* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{n : n, `el*` : el*} {{`%`_u32(n):Bu32} {el:BX^n{el <- `el*`}}} => el^n{el <- `el*`} - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bname : name - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{name : name, `b*` : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name - -- if ($utf8(name!`%`_name.0) = b*{b <- `b*`}) - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Btypeidx : typeidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Btagidx : tagidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bglobalidx : globalidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bmemidx : memidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Btableidx : tableidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bfuncidx : funcidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bdataidx : dataidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Belemidx : elemidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Blocalidx : localidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bfieldidx : fieldidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} x:Bu32 => x - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Blabelidx : labelidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{l : labelidx} l:Bu32 => l - -;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -grammar Bexternidx : externidx - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} {{0x00} {x:Bfuncidx}} => FUNC_externidx(x) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} {{0x01} {x:Btableidx}} => TABLE_externidx(x) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} {{0x02} {x:Bmemidx}} => MEM_externidx(x) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} {{0x03} {x:Bglobalidx}} => GLOBAL_externidx(x) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{x : idx} {{0x04} {x:Btagidx}} => TAG_externidx(x) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bnumtype : numtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x7C => F64_numtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x7D => F32_numtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x7E => I64_numtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x7F => I32_numtype - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bvectype : vectype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x7B => V128_vectype - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Babsheaptype : heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x69 => EXN_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6A => ARRAY_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6B => STRUCT_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6C => I31_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6D => EQ_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6E => ANY_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x6F => EXTERN_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x70 => FUNC_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x71 => NONE_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x72 => NOEXTERN_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x73 => NOFUNC_heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x74 => NOEXN_heaptype - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bheaptype : heaptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ht : heaptype} ht:Babsheaptype => ht - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{x33 : s33} x33:Bs33 => _IDX_heaptype($s33_to_u32(x33)) - -- if (x33!`%`_sN.0 >= (0 : nat <:> int)) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Breftype : reftype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ht : heaptype} {{0x63} {ht:Bheaptype}} => REF_reftype(?(NULL_null), ht) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ht : heaptype} {{0x64} {ht:Bheaptype}} => REF_reftype(?(), ht) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ht : heaptype} ht:Babsheaptype => REF_reftype(?(NULL_null), ht) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bvaltype : valtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{nt : numtype} nt:Bnumtype => (nt : numtype <: valtype) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{vt : vectype} vt:Bvectype => (vt : vectype <: valtype) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{rt : reftype} rt:Breftype => (rt : reftype <: valtype) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bresulttype : resulttype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`t*` : valtype*} t*{t <- `t*`}:Blist(syntax valtype, grammar Bvaltype) => `%`_resulttype(t*{t <- `t*`}) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bmut : mut? - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x00 => ?() - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x01 => ?(MUT_mut) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bpacktype : packtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x77 => I16_packtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod 0x78 => I8_packtype - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bstoragetype : storagetype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{t : valtype} t:Bvaltype => (t : valtype <: storagetype) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{pt : packtype} pt:Bpacktype => (pt : packtype <: storagetype) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bfieldtype : fieldtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`mut?` : mut?, zt : storagetype} {{zt:Bstoragetype} {mut?{mut <- `mut?`}:Bmut}} => `%%`_fieldtype(mut?{mut <- `mut?`}, zt) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bcomptype : comptype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ft : fieldtype} {{0x5E} {ft:Bfieldtype}} => ARRAY_comptype(ft) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`ft*` : fieldtype*} {{0x5F} {ft*{ft <- `ft*`}:Blist(syntax fieldtype, grammar Bfieldtype)}} => STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`t_1*` : valtype*, `t_2*` : valtype*} {{0x60} {`%`_resulttype(t_1*{t_1 <- `t_1*`}):Bresulttype} {`%`_resulttype(t_2*{t_2 <- `t_2*`}):Bresulttype}} => `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bsubtype : subtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`x*` : idx*, ct : comptype} {{0x4F} {x*{x <- `x*`}:Blist(syntax typeidx, grammar Btypeidx)} {ct:Bcomptype}} => SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, ct) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`x*` : idx*, ct : comptype} {{0x50} {x*{x <- `x*`}:Blist(syntax typeidx, grammar Btypeidx)} {ct:Bcomptype}} => SUB_subtype(?(), _IDX_typeuse(x)*{x <- `x*`}, ct) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ct : comptype} ct:Bcomptype => SUB_subtype(?(FINAL_final), [], ct) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Brectype : rectype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`st*` : subtype*} {{0x4E} {st*{st <- `st*`}:Blist(syntax subtype, grammar Bsubtype)}} => REC_rectype(`%`_list(st*{st <- `st*`})) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{st : subtype} st:Bsubtype => REC_rectype(`%`_list([st])) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Blimits : (addrtype, limits) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{n : n} {{0x00} {`%`_u64(n):Bu64}} => (I32_addrtype, `[%..%]`_limits(`%`_u64(n), ?())) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{n : n, m : m} {{0x01} {`%`_u64(n):Bu64} {`%`_u64(m):Bu64}} => (I32_addrtype, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{n : n} {{0x04} {`%`_u64(n):Bu64}} => (I64_addrtype, `[%..%]`_limits(`%`_u64(n), ?())) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{n : n, m : m} {{0x05} {`%`_u64(n):Bu64} {`%`_u64(m):Bu64}} => (I64_addrtype, `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m)))) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Btagtype : tagtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{x : idx} {{0x00} {x:Btypeidx}} => _IDX_tagtype(x) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bglobaltype : globaltype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{`mut?` : mut?, t : valtype} {{t:Bvaltype} {mut?{mut <- `mut?`}:Bmut}} => `%%`_globaltype(mut?{mut <- `mut?`}, t) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bmemtype : memtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{at : addrtype, lim : limits} (at, lim):Blimits => `%%PAGE`_memtype(at, lim) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Btabletype : tabletype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{at : addrtype, lim : limits, rt : reftype} {{rt:Breftype} {(at, lim):Blimits}} => `%%%`_tabletype(at, lim, rt) - -;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec -grammar Bexterntype : externtype - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{x : idx} {{0x00} {x:Btypeidx}} => FUNC_externtype(_IDX_typeuse(x)) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{tt : tabletype} {{0x01} {tt:Btabletype}} => TABLE_externtype(tt) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{mt : memtype} {{0x02} {mt:Bmemtype}} => MEM_externtype(mt) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{gt : globaltype} {{0x03} {gt:Bglobaltype}} => GLOBAL_externtype(gt) - ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{jt : tagtype} {{0x04} {jt:Btagtype}} => TAG_externtype(jt) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Bcastop : castop - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod 0x00 => (?(), ?()) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod 0x01 => (?(NULL_null), ?()) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod 0x02 => (?(), ?(NULL_null)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod 0x03 => (?(NULL_null), ?(NULL_null)) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Bblocktype : blocktype - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod 0x40 => _RESULT_blocktype(?()) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{t : valtype} t:Bvaltype => _RESULT_blocktype(?(t)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{i : s33} i:Bs33 => _IDX_blocktype(`%`_typeidx((i!`%`_sN.0 : int <:> nat))) - -- if (i!`%`_sN.0 >= (0 : nat <:> int)) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Bcatch : catch - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{x : idx, l : labelidx} {{0x00} {x:Btagidx} {l:Blabelidx}} => CATCH_catch(x, l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{x : idx, l : labelidx} {{0x01} {x:Btagidx} {l:Blabelidx}} => CATCH_REF_catch(x, l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{l : labelidx} {{0x02} {l:Blabelidx}} => CATCH_ALL_catch(l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{l : labelidx} {{0x03} {l:Blabelidx}} => CATCH_ALL_REF_catch(l) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Bmemarg : memidxop - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{n : n, m : m} {{`%`_u32(n):Bu32} {`%`_u64(m):Bu64}} => (`%`_memidx(0), {ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) - -- if (n < (2 ^ 6)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{x : idx, n : n, m : m} {{`%`_u32(n):Bu32} {x:Bmemidx} {`%`_u64(m):Bu64}} => (x, {ALIGN `%`_u32((((n : nat <:> int) - ((2 ^ 6) : nat <:> int)) : int <:> nat)), OFFSET `%`_u64(m)}) - -- if (((2 ^ 6) <= n) /\ (n < (2 ^ 7))) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Blaneidx : laneidx - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{l : labelidx} `%`_byte(l!`%`_uN.0):Bbyte => `%`_laneidx(l!`%`_uN.0) - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:793.1-807.71 -grammar Binstr : instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:8.5-8.24 - prod 0x00 => UNREACHABLE_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:9.5-9.16 - prod 0x01 => NOP_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:10.5-10.17 - prod 0x1A => DROP_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:11.5-11.19 - prod 0x1B => SELECT_instr(?()) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:12.5-12.41 - prod{`t*` : valtype*} {{0x1C} {t*{t <- `t*`}:Blist(syntax valtype, grammar Bvaltype)}} => SELECT_instr(?(t*{t <- `t*`})) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:32.5-32.57 - prod{bt : blocktype, `in*` : instr*} {{0x02} {bt:Bblocktype} {in:Binstr*{in <- `in*`}} {0x0B}} => BLOCK_instr(bt, in*{in <- `in*`}) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:33.5-33.56 - prod{bt : blocktype, `in*` : instr*} {{0x03} {bt:Bblocktype} {in:Binstr*{in <- `in*`}} {0x0B}} => LOOP_instr(bt, in*{in <- `in*`}) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:34.5-34.63 - prod{bt : blocktype, `in*` : instr*} {{0x04} {bt:Bblocktype} {in:Binstr*{in <- `in*`}} {0x0B}} => `IF%%ELSE%`_instr(bt, in*{in <- `in*`}, []) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:35.5-36.55 - prod{bt : blocktype, `in_1*` : instr*, `in_2*` : instr*} {{0x04} {bt:Bblocktype} {in_1:Binstr*{in_1 <- `in_1*`}} {0x05} {in_2:Binstr*{in_2 <- `in_2*`}} {0x0B}} => `IF%%ELSE%`_instr(bt, in_1*{in_1 <- `in_1*`}, in_2*{in_2 <- `in_2*`}) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:40.5-40.30 - prod{x : idx} {{0x08} {x:Btagidx}} => THROW_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:41.5-41.22 - prod 0x0A => THROW_REF_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:42.5-42.29 - prod{l : labelidx} {{0x0C} {l:Blabelidx}} => BR_instr(l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:43.5-43.32 - prod{l : labelidx} {{0x0D} {l:Blabelidx}} => BR_IF_instr(l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:44.5-44.62 - prod{`l*` : labelidx*, l_n : labelidx} {{0x0E} {l*{l <- `l*`}:Blist(syntax labelidx, grammar Blabelidx)} {l_n:Blabelidx}} => BR_TABLE_instr(l*{l <- `l*`}, l_n) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:45.5-45.19 - prod 0x0F => RETURN_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:46.5-46.30 - prod{x : idx} {{0x10} {x:Bfuncidx}} => CALL_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:47.5-47.60 - prod{x : idx, y : idx} {{0x11} {y:Btypeidx} {x:Btableidx}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:48.5-48.37 - prod{x : idx} {{0x12} {x:Bfuncidx}} => RETURN_CALL_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:49.5-49.67 - prod{x : idx, y : idx} {{0x13} {y:Btypeidx} {x:Btableidx}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:50.5-50.41 - prod{x : idx} {{0x14} {x:Btypeidx}} => CALL_REF_instr(_IDX_typeuse(x)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:51.5-51.48 - prod{x : idx} {{0x15} {x:Btypeidx}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:52.5-52.81 - prod{bt : blocktype, `c*` : catch*, `in*` : instr*} {{0x1F} {bt:Bblocktype} {c*{c <- `c*`}:Blist(syntax catch, grammar Bcatch)} {in:Binstr*{in <- `in*`}} {0x0B}} => TRY_TABLE_instr(bt, `%`_list(c*{c <- `c*`}), in*{in <- `in*`}) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:53.5-53.37 - prod{l : labelidx} {{0xD5} {l:Blabelidx}} => BR_ON_NULL_instr(l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:54.5-54.41 - prod{l : labelidx} {{0xD6} {l:Blabelidx}} => BR_ON_NON_NULL_instr(l) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:55.5-56.100 - prod{l : labelidx, `null_1?` : null?, ht_1 : heaptype, `null_2?` : null?, ht_2 : heaptype} {{0xFB} {`%`_u32(24):Bu32} {(null_1?{null_1 <- `null_1?`}, null_2?{null_2 <- `null_2?`}):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_instr(l, REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(null_2?{null_2 <- `null_2?`}, ht_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:57.5-58.105 - prod{l : labelidx, `null_1?` : null?, ht_1 : heaptype, `null_2?` : null?, ht_2 : heaptype} {{0xFB} {`%`_u32(25):Bu32} {(null_1?{null_1 <- `null_1?`}, null_2?{null_2 <- `null_2?`}):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_FAIL_instr(l, REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(null_2?{null_2 <- `null_2?`}, ht_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:71.5-71.36 - prod{x : idx} {{0x20} {x:Blocalidx}} => `LOCAL.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:72.5-72.36 - prod{x : idx} {{0x21} {x:Blocalidx}} => `LOCAL.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:73.5-73.36 - prod{x : idx} {{0x22} {x:Blocalidx}} => `LOCAL.TEE`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:77.5-77.38 - prod{x : idx} {{0x23} {x:Bglobalidx}} => `GLOBAL.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:78.5-78.38 - prod{x : idx} {{0x24} {x:Bglobalidx}} => `GLOBAL.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:85.5-85.36 - prod{x : idx} {{0x25} {x:Btableidx}} => `TABLE.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:86.5-86.36 - prod{x : idx} {{0x26} {x:Btableidx}} => `TABLE.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:87.5-87.58 - prod{x : idx, y : idx} {{0xFC} {`%`_u32(12):Bu32} {y:Belemidx} {x:Btableidx}} => `TABLE.INIT`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:88.5-88.43 - prod{x : idx} {{0xFC} {`%`_u32(13):Bu32} {x:Belemidx}} => `ELEM.DROP`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:89.5-89.67 - prod{x_1 : idx, x_2 : idx} {{0xFC} {`%`_u32(14):Bu32} {x_1:Btableidx} {x_2:Btableidx}} => `TABLE.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:90.5-90.45 - prod{x : idx} {{0xFC} {`%`_u32(15):Bu32} {x:Btableidx}} => `TABLE.GROW`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:91.5-91.45 - prod{x : idx} {{0xFC} {`%`_u32(16):Bu32} {x:Btableidx}} => `TABLE.SIZE`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:92.5-92.45 - prod{x : idx} {{0xFC} {`%`_u32(17):Bu32} {x:Btableidx}} => `TABLE.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:105.5-105.41 - prod{x : idx, ao : memarg} {{0x28} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:106.5-106.41 - prod{x : idx, ao : memarg} {{0x29} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:107.5-107.41 - prod{x : idx, ao : memarg} {{0x2A} {(x, ao):Bmemarg}} => LOAD_instr(F32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:108.5-108.41 - prod{x : idx, ao : memarg} {{0x2B} {(x, ao):Bmemarg}} => LOAD_instr(F64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:109.5-109.50 - prod{x : idx, ao : memarg} {{0x2C} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:110.5-110.50 - prod{x : idx, ao : memarg} {{0x2D} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:111.5-111.51 - prod{x : idx, ao : memarg} {{0x2E} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:112.5-112.51 - prod{x : idx, ao : memarg} {{0x2F} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:113.5-113.50 - prod{x : idx, ao : memarg} {{0x30} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:114.5-114.50 - prod{x : idx, ao : memarg} {{0x31} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:115.5-115.51 - prod{x : idx, ao : memarg} {{0x32} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:116.5-116.51 - prod{x : idx, ao : memarg} {{0x33} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:117.5-117.51 - prod{x : idx, ao : memarg} {{0x34} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:118.5-118.51 - prod{x : idx, ao : memarg} {{0x35} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:119.5-119.42 - prod{x : idx, ao : memarg} {{0x36} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:120.5-120.42 - prod{x : idx, ao : memarg} {{0x37} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:121.5-121.42 - prod{x : idx, ao : memarg} {{0x38} {(x, ao):Bmemarg}} => STORE_instr(F32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:122.5-122.42 - prod{x : idx, ao : memarg} {{0x39} {(x, ao):Bmemarg}} => STORE_instr(F64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:123.5-123.45 - prod{x : idx, ao : memarg} {{0x3A} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:124.5-124.46 - prod{x : idx, ao : memarg} {{0x3B} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:125.5-125.45 - prod{x : idx, ao : memarg} {{0x3C} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:126.5-126.46 - prod{x : idx, ao : memarg} {{0x3D} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:127.5-127.46 - prod{x : idx, ao : memarg} {{0x3E} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(32)))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:128.5-128.36 - prod{x : idx} {{0x3F} {x:Bmemidx}} => `MEMORY.SIZE`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:129.5-129.36 - prod{x : idx} {{0x40} {x:Bmemidx}} => `MEMORY.GROW`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:130.5-130.56 - prod{x : idx, y : idx} {{0xFC} {`%`_u32(8):Bu32} {y:Bdataidx} {x:Bmemidx}} => `MEMORY.INIT`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:131.5-131.42 - prod{x : idx} {{0xFC} {`%`_u32(9):Bu32} {x:Bdataidx}} => `DATA.DROP`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:132.5-132.64 - prod{x_1 : idx, x_2 : idx} {{0xFC} {`%`_u32(10):Bu32} {x_1:Bmemidx} {x_2:Bmemidx}} => `MEMORY.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:133.5-133.44 - prod{x : idx} {{0xFC} {`%`_u32(11):Bu32} {x:Bmemidx}} => `MEMORY.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:140.5-140.37 - prod{ht : heaptype} {{0xD0} {ht:Bheaptype}} => `REF.NULL`_instr(ht) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:141.5-141.24 - prod 0xD1 => `REF.IS_NULL`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:142.5-142.34 - prod{x : idx} {{0xD2} {x:Bfuncidx}} => `REF.FUNC`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:143.5-143.19 - prod 0xD3 => `REF.EQ`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:144.5-144.28 - prod 0xD4 => `REF.AS_NON_NULL`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:145.5-145.51 - prod{ht : heaptype} {{0xFB} {`%`_u32(20):Bu32} {ht:Bheaptype}} => `REF.TEST`_instr(REF_reftype(?(), ht)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:146.5-146.56 - prod{ht : heaptype} {{0xFB} {`%`_u32(21):Bu32} {ht:Bheaptype}} => `REF.TEST`_instr(REF_reftype(?(NULL_null), ht)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:147.5-147.51 - prod{ht : heaptype} {{0xFB} {`%`_u32(22):Bu32} {ht:Bheaptype}} => `REF.CAST`_instr(REF_reftype(?(), ht)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:148.5-148.56 - prod{ht : heaptype} {{0xFB} {`%`_u32(23):Bu32} {ht:Bheaptype}} => `REF.CAST`_instr(REF_reftype(?(NULL_null), ht)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:152.5-152.43 - prod{x : idx} {{0xFB} {`%`_u32(0):Bu32} {x:Btypeidx}} => `STRUCT.NEW`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:153.5-153.51 - prod{x : idx} {{0xFB} {`%`_u32(1):Bu32} {x:Btypeidx}} => `STRUCT.NEW_DEFAULT`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:154.5-154.57 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(2):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(), x, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:155.5-155.59 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(3):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(S_sx), x, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:156.5-156.59 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(4):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(U_sx), x, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:157.5-157.57 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(5):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.SET`_instr(x, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:161.5-161.42 - prod{x : idx} {{0xFB} {`%`_u32(6):Bu32} {x:Btypeidx}} => `ARRAY.NEW`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:162.5-162.50 - prod{x : idx} {{0xFB} {`%`_u32(7):Bu32} {x:Btypeidx}} => `ARRAY.NEW_DEFAULT`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:163.5-163.57 - prod{x : idx, n : n} {{0xFB} {`%`_u32(8):Bu32} {x:Btypeidx} {`%`_u32(n):Bu32}} => `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:164.5-164.60 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(9):Bu32} {x:Btypeidx} {y:Bdataidx}} => `ARRAY.NEW_DATA`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:165.5-165.61 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(10):Bu32} {x:Btypeidx} {y:Belemidx}} => `ARRAY.NEW_ELEM`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:166.5-166.43 - prod{x : idx} {{0xFB} {`%`_u32(11):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(), x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:167.5-167.45 - prod{x : idx} {{0xFB} {`%`_u32(12):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(S_sx), x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:168.5-168.45 - prod{x : idx} {{0xFB} {`%`_u32(13):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(U_sx), x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:169.5-169.43 - prod{x : idx} {{0xFB} {`%`_u32(14):Bu32} {x:Btypeidx}} => `ARRAY.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:170.5-170.30 - prod {{0xFB} {`%`_u32(15):Bu32}} => `ARRAY.LEN`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:171.5-171.44 - prod{x : idx} {{0xFB} {`%`_u32(16):Bu32} {x:Btypeidx}} => `ARRAY.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:172.5-172.65 - prod{x_1 : idx, x_2 : idx} {{0xFB} {`%`_u32(17):Bu32} {x_1:Btypeidx} {x_2:Btypeidx}} => `ARRAY.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:173.5-173.62 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(18):Bu32} {x:Btypeidx} {y:Bdataidx}} => `ARRAY.INIT_DATA`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:174.5-174.62 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(19):Bu32} {x:Btypeidx} {y:Belemidx}} => `ARRAY.INIT_ELEM`_instr(x, y) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:178.5-178.39 - prod {{0xFB} {`%`_u32(26):Bu32}} => `ANY.CONVERT_EXTERN`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:179.5-179.39 - prod {{0xFB} {`%`_u32(27):Bu32}} => `EXTERN.CONVERT_ANY`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:183.5-183.28 - prod {{0xFB} {`%`_u32(28):Bu32}} => `REF.I31`_instr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:184.5-184.30 - prod {{0xFB} {`%`_u32(29):Bu32}} => `I31.GET`_instr(S_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:185.5-185.30 - prod {{0xFB} {`%`_u32(30):Bu32}} => `I31.GET`_instr(U_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:192.5-192.31 - prod{i : i32} {{0x41} {i:Bi32}} => CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, i)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:193.5-193.31 - prod{i : i64} {{0x42} {i:Bi64}} => CONST_instr(I64_numtype, mk_num__0_num_(I64_Inn, i)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:194.5-194.31 - prod{p : f32} {{0x43} {p:Bf32}} => CONST_instr(F32_numtype, mk_num__1_num_(F32_Fnn, p)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:195.5-195.31 - prod{p : f64} {{0x44} {p:Bf64}} => CONST_instr(F64_numtype, mk_num__1_num_(F64_Fnn, p)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:199.5-199.27 - prod 0x45 => TESTOP_instr(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:203.5-203.25 - prod 0x46 => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, EQ_relop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:204.5-204.25 - prod 0x47 => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, NE_relop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:205.5-205.27 - prod 0x48 => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:206.5-206.27 - prod 0x49 => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:207.5-207.27 - prod 0x4A => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:208.5-208.27 - prod 0x4B => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:209.5-209.27 - prod 0x4C => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:210.5-210.27 - prod 0x4D => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:211.5-211.27 - prod 0x4E => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:212.5-212.27 - prod 0x4F => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:216.5-216.27 - prod 0x50 => TESTOP_instr(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:220.5-220.25 - prod 0x51 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, EQ_relop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:221.5-221.25 - prod 0x52 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, NE_relop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:222.5-222.27 - prod 0x53 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:223.5-223.27 - prod 0x54 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:224.5-224.27 - prod 0x55 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:225.5-225.27 - prod 0x56 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:226.5-226.27 - prod 0x57 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:227.5-227.27 - prod 0x58 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:228.5-228.27 - prod 0x59 => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:229.5-229.27 - prod 0x5A => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:233.5-233.25 - prod 0x5B => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, EQ_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:234.5-234.25 - prod 0x5C => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, NE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:235.5-235.25 - prod 0x5D => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, LT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:236.5-236.25 - prod 0x5E => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, GT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:237.5-237.25 - prod 0x5F => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, LE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:238.5-238.25 - prod 0x60 => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, GE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:242.5-242.25 - prod 0x61 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, EQ_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:243.5-243.25 - prod 0x62 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, NE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:244.5-244.25 - prod 0x63 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, LT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:245.5-245.25 - prod 0x64 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, GT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:246.5-246.25 - prod 0x65 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, LE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:247.5-247.25 - prod 0x66 => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:251.5-251.25 - prod 0x67 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:252.5-252.25 - prod 0x68 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:253.5-253.28 - prod 0x69 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:257.5-257.26 - prod 0x6A => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:258.5-258.26 - prod 0x6B => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:259.5-259.26 - prod 0x6C => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:260.5-260.28 - prod 0x6D => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:261.5-261.28 - prod 0x6E => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:262.5-262.28 - prod 0x6F => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:263.5-263.28 - prod 0x70 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:264.5-264.26 - prod 0x71 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:265.5-265.25 - prod 0x72 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:266.5-266.26 - prod 0x73 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:267.5-267.26 - prod 0x74 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:268.5-268.28 - prod 0x75 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:269.5-269.28 - prod 0x76 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:270.5-270.27 - prod 0x77 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:271.5-271.27 - prod 0x78 => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:275.5-275.25 - prod 0x79 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:276.5-276.25 - prod 0x7A => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:277.5-277.28 - prod 0x7B => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:281.5-281.31 - prod 0xC0 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(8)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:282.5-282.32 - prod 0xC1 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(16)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:286.5-286.31 - prod 0xC2 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(8)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:287.5-287.32 - prod 0xC3 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(16)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:288.5-288.32 - prod 0xC4 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(32)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:292.5-292.26 - prod 0x7C => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:293.5-293.26 - prod 0x7D => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:294.5-294.26 - prod 0x7E => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:295.5-295.28 - prod 0x7F => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:296.5-296.28 - prod 0x80 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:297.5-297.28 - prod 0x81 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:298.5-298.28 - prod 0x82 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:299.5-299.26 - prod 0x83 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:300.5-300.25 - prod 0x84 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:301.5-301.26 - prod 0x85 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:302.5-302.26 - prod 0x86 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:303.5-303.28 - prod 0x87 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:304.5-304.28 - prod 0x88 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:305.5-305.27 - prod 0x89 => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:306.5-306.27 - prod 0x8A => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:310.5-310.25 - prod 0x8B => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:311.5-311.25 - prod 0x8C => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:312.5-312.26 - prod 0x8D => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:313.5-313.27 - prod 0x8E => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:314.5-314.27 - prod 0x8F => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:315.5-315.29 - prod 0x90 => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:316.5-316.26 - prod 0x91 => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:320.5-320.26 - prod 0x92 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:321.5-321.26 - prod 0x93 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:322.5-322.26 - prod 0x94 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:323.5-323.26 - prod 0x95 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:324.5-324.26 - prod 0x96 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:325.5-325.26 - prod 0x97 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:326.5-326.31 - prod 0x98 => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:330.5-330.25 - prod 0x99 => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:331.5-331.25 - prod 0x9A => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:332.5-332.26 - prod 0x9B => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:333.5-333.27 - prod 0x9C => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:334.5-334.27 - prod 0x9D => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:335.5-335.29 - prod 0x9E => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:336.5-336.26 - prod 0x9F => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:340.5-340.26 - prod 0xA0 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:341.5-341.26 - prod 0xA1 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:342.5-342.26 - prod 0xA2 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:343.5-343.26 - prod 0xA3 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:344.5-344.26 - prod 0xA4 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:345.5-345.26 - prod 0xA5 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:346.5-346.31 - prod 0xA6 => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:351.5-351.31 - prod 0xA7 => CVTOP_instr(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:352.5-352.34 - prod 0xA8 => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:353.5-353.34 - prod 0xA9 => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:354.5-354.34 - prod 0xAA => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:355.5-355.34 - prod 0xAB => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:356.5-356.35 - prod 0xAC => CVTOP_instr(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:357.5-357.35 - prod 0xAD => CVTOP_instr(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:358.5-358.34 - prod 0xAE => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:359.5-359.34 - prod 0xAF => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:360.5-360.34 - prod 0xB0 => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:361.5-361.34 - prod 0xB1 => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:362.5-362.36 - prod 0xB2 => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:363.5-363.36 - prod 0xB3 => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:364.5-364.36 - prod 0xB4 => CVTOP_instr(F32_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:365.5-365.36 - prod 0xB5 => CVTOP_instr(F32_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:366.5-366.33 - prod 0xB6 => CVTOP_instr(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:367.5-367.36 - prod 0xB7 => CVTOP_instr(F64_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:368.5-368.36 - prod 0xB8 => CVTOP_instr(F64_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:369.5-369.36 - prod 0xB9 => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:370.5-370.36 - prod 0xBA => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:371.5-371.34 - prod 0xBB => CVTOP_instr(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:372.5-372.38 - prod 0xBC => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:373.5-373.38 - prod 0xBD => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:374.5-374.38 - prod 0xBE => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:375.5-375.38 - prod 0xBF => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:379.5-379.45 - prod {{0xFC} {`%`_u32(0):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:380.5-380.45 - prod {{0xFC} {`%`_u32(1):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:381.5-381.45 - prod {{0xFC} {`%`_u32(2):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:382.5-382.45 - prod {{0xFC} {`%`_u32(3):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:383.5-383.45 - prod {{0xFC} {`%`_u32(4):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:384.5-384.45 - prod {{0xFC} {`%`_u32(5):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:385.5-385.45 - prod {{0xFC} {`%`_u32(6):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:386.5-386.45 - prod {{0xFC} {`%`_u32(7):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:396.5-396.50 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(0):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:397.5-397.70 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(1):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:398.5-398.70 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(2):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:399.5-399.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(3):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:400.5-400.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(4):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:401.5-401.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(5):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:402.5-402.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(6):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:403.5-403.61 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(7):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(8))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:404.5-404.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(8):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(16))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:405.5-405.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(9):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(32))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:406.5-406.63 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(10):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(64))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:407.5-407.52 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(11):Bu32} {(x, ao):Bmemarg}} => VSTORE_instr(V128_vectype, x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:408.5-408.72 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(84):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:409.5-409.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(85):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:410.5-410.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(86):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:411.5-411.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(87):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:412.5-412.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(88):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:413.5-413.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(89):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:414.5-414.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(90):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:415.5-415.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(91):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:416.5-416.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(92):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(32))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:417.5-417.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(93):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(64))), x, ao) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:421.5-421.72 - prod{`b*` : byte*} {{0xFD} {`%`_u32(12):Bu32} {b:Bbyte^16{b <- `b*`}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, b^16{b <- `b*`})) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:425.5-425.61 - prod{`l*` : labelidx*} {{0xFD} {`%`_u32(13):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx^16{l <- `l*`}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_laneidx(l!`%`_uN.0)^16{l <- `l*`}) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:426.5-426.49 - prod {{0xFD} {`%`_u32(14):Bu32}} => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:427.5-427.58 - prod {{0xFD} {`%`_u32(256):Bu32}} => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:431.5-431.38 - prod {{0xFD} {`%`_u32(15):Bu32}} => VSPLAT_instr(`%X%`_shape(I8_lanetype, `%`_dim(16))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:432.5-432.38 - prod {{0xFD} {`%`_u32(16):Bu32}} => VSPLAT_instr(`%X%`_shape(I16_lanetype, `%`_dim(8))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:433.5-433.38 - prod {{0xFD} {`%`_u32(17):Bu32}} => VSPLAT_instr(`%X%`_shape(I32_lanetype, `%`_dim(4))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:434.5-434.38 - prod {{0xFD} {`%`_u32(18):Bu32}} => VSPLAT_instr(`%X%`_shape(I64_lanetype, `%`_dim(2))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:435.5-435.38 - prod {{0xFD} {`%`_u32(19):Bu32}} => VSPLAT_instr(`%X%`_shape(F32_lanetype, `%`_dim(4))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:436.5-436.38 - prod {{0xFD} {`%`_u32(20):Bu32}} => VSPLAT_instr(`%X%`_shape(F64_lanetype, `%`_dim(2))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:440.5-440.60 - prod{l : labelidx} {{0xFD} {`%`_u32(21):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:441.5-441.60 - prod{l : labelidx} {{0xFD} {`%`_u32(22):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:442.5-442.58 - prod{l : labelidx} {{0xFD} {`%`_u32(23):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:443.5-443.60 - prod{l : labelidx} {{0xFD} {`%`_u32(24):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:444.5-444.60 - prod{l : labelidx} {{0xFD} {`%`_u32(25):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:445.5-445.58 - prod{l : labelidx} {{0xFD} {`%`_u32(26):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:446.5-446.58 - prod{l : labelidx} {{0xFD} {`%`_u32(27):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:447.5-447.58 - prod{l : labelidx} {{0xFD} {`%`_u32(28):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:448.5-448.58 - prod{l : labelidx} {{0xFD} {`%`_u32(29):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:449.5-449.58 - prod{l : labelidx} {{0xFD} {`%`_u32(30):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:450.5-450.58 - prod{l : labelidx} {{0xFD} {`%`_u32(31):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:451.5-451.58 - prod{l : labelidx} {{0xFD} {`%`_u32(32):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:452.5-452.58 - prod{l : labelidx} {{0xFD} {`%`_u32(33):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:453.5-453.58 - prod{l : labelidx} {{0xFD} {`%`_u32(34):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%`_laneidx(l!`%`_uN.0)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:457.5-457.41 - prod {{0xFD} {`%`_u32(35):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:458.5-458.41 - prod {{0xFD} {`%`_u32(36):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:459.5-459.43 - prod {{0xFD} {`%`_u32(37):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:460.5-460.43 - prod {{0xFD} {`%`_u32(38):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:461.5-461.43 - prod {{0xFD} {`%`_u32(39):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:462.5-462.43 - prod {{0xFD} {`%`_u32(40):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:463.5-463.43 - prod {{0xFD} {`%`_u32(41):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:464.5-464.43 - prod {{0xFD} {`%`_u32(42):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:465.5-465.43 - prod {{0xFD} {`%`_u32(43):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:466.5-466.43 - prod {{0xFD} {`%`_u32(44):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:470.5-470.41 - prod {{0xFD} {`%`_u32(45):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:471.5-471.41 - prod {{0xFD} {`%`_u32(46):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:472.5-472.43 - prod {{0xFD} {`%`_u32(47):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:473.5-473.43 - prod {{0xFD} {`%`_u32(48):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:474.5-474.43 - prod {{0xFD} {`%`_u32(49):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:475.5-475.43 - prod {{0xFD} {`%`_u32(50):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:476.5-476.43 - prod {{0xFD} {`%`_u32(51):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:477.5-477.43 - prod {{0xFD} {`%`_u32(52):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:478.5-478.43 - prod {{0xFD} {`%`_u32(53):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:479.5-479.43 - prod {{0xFD} {`%`_u32(54):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:483.5-483.41 - prod {{0xFD} {`%`_u32(55):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:484.5-484.41 - prod {{0xFD} {`%`_u32(56):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:485.5-485.43 - prod {{0xFD} {`%`_u32(57):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:486.5-486.43 - prod {{0xFD} {`%`_u32(58):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:487.5-487.43 - prod {{0xFD} {`%`_u32(59):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:488.5-488.43 - prod {{0xFD} {`%`_u32(60):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:489.5-489.43 - prod {{0xFD} {`%`_u32(61):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:490.5-490.43 - prod {{0xFD} {`%`_u32(62):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:491.5-491.43 - prod {{0xFD} {`%`_u32(63):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:492.5-492.43 - prod {{0xFD} {`%`_u32(64):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:496.5-496.41 - prod {{0xFD} {`%`_u32(65):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:497.5-497.41 - prod {{0xFD} {`%`_u32(66):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:498.5-498.41 - prod {{0xFD} {`%`_u32(67):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:499.5-499.41 - prod {{0xFD} {`%`_u32(68):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:500.5-500.41 - prod {{0xFD} {`%`_u32(69):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:501.5-501.41 - prod {{0xFD} {`%`_u32(70):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:505.5-505.41 - prod {{0xFD} {`%`_u32(71):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:506.5-506.41 - prod {{0xFD} {`%`_u32(72):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:507.5-507.41 - prod {{0xFD} {`%`_u32(73):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:508.5-508.41 - prod {{0xFD} {`%`_u32(74):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:509.5-509.41 - prod {{0xFD} {`%`_u32(75):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:510.5-510.41 - prod {{0xFD} {`%`_u32(76):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:514.5-514.36 - prod {{0xFD} {`%`_u32(77):Bu32}} => VVUNOP_instr(V128_vectype, NOT_vvunop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:518.5-518.37 - prod {{0xFD} {`%`_u32(78):Bu32}} => VVBINOP_instr(V128_vectype, AND_vvbinop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:519.5-519.40 - prod {{0xFD} {`%`_u32(79):Bu32}} => VVBINOP_instr(V128_vectype, ANDNOT_vvbinop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:520.5-520.36 - prod {{0xFD} {`%`_u32(80):Bu32}} => VVBINOP_instr(V128_vectype, OR_vvbinop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:521.5-521.37 - prod {{0xFD} {`%`_u32(81):Bu32}} => VVBINOP_instr(V128_vectype, XOR_vvbinop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:525.5-525.44 - prod {{0xFD} {`%`_u32(82):Bu32}} => VVTERNOP_instr(V128_vectype, BITSELECT_vvternop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:529.5-529.43 - prod {{0xFD} {`%`_u32(83):Bu32}} => VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:533.5-533.41 - prod {{0xFD} {`%`_u32(96):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:534.5-534.41 - prod {{0xFD} {`%`_u32(97):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:535.5-535.44 - prod {{0xFD} {`%`_u32(98):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:539.5-539.48 - prod {{0xFD} {`%`_u32(99):Bu32}} => VTESTOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:543.5-543.41 - prod {{0xFD} {`%`_u32(100):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:547.5-547.53 - prod {{0xFD} {`%`_u32(101):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), S_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:548.5-548.53 - prod {{0xFD} {`%`_u32(102):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), U_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:552.5-552.45 - prod {{0xFD} {`%`_u32(107):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:553.5-553.47 - prod {{0xFD} {`%`_u32(108):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:554.5-554.47 - prod {{0xFD} {`%`_u32(109):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:558.5-558.43 - prod {{0xFD} {`%`_u32(110):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:559.5-559.49 - prod {{0xFD} {`%`_u32(111):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:560.5-560.49 - prod {{0xFD} {`%`_u32(112):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:561.5-561.43 - prod {{0xFD} {`%`_u32(113):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:562.5-562.49 - prod {{0xFD} {`%`_u32(114):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:563.5-563.49 - prod {{0xFD} {`%`_u32(115):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:564.5-564.45 - prod {{0xFD} {`%`_u32(118):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:565.5-565.45 - prod {{0xFD} {`%`_u32(119):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:566.5-566.45 - prod {{0xFD} {`%`_u32(120):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:567.5-567.45 - prod {{0xFD} {`%`_u32(121):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:568.5-568.46 - prod {{0xFD} {`%`_u32(123):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:572.5-572.70 - prod {{0xFD} {`%`_u32(124):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:573.5-573.70 - prod {{0xFD} {`%`_u32(125):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:577.5-577.42 - prod {{0xFD} {`%`_u32(128):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:578.5-578.42 - prod {{0xFD} {`%`_u32(129):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:582.5-582.53 - prod {{0xFD} {`%`_u32(130):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:583.5-583.43 - prod {{0xFD} {`%`_u32(142):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:584.5-584.49 - prod {{0xFD} {`%`_u32(143):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:585.5-585.49 - prod {{0xFD} {`%`_u32(144):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:586.5-586.43 - prod {{0xFD} {`%`_u32(145):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:587.5-587.49 - prod {{0xFD} {`%`_u32(146):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:588.5-588.49 - prod {{0xFD} {`%`_u32(147):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:589.5-589.43 - prod {{0xFD} {`%`_u32(149):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:590.5-590.45 - prod {{0xFD} {`%`_u32(150):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:591.5-591.45 - prod {{0xFD} {`%`_u32(151):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:592.5-592.45 - prod {{0xFD} {`%`_u32(152):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:593.5-593.45 - prod {{0xFD} {`%`_u32(153):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:594.5-594.46 - prod {{0xFD} {`%`_u32(155):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:595.5-595.57 - prod {{0xFD} {`%`_u32(273):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:599.5-599.49 - prod {{0xFD} {`%`_u32(131):Bu32}} => VTESTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:603.5-603.41 - prod {{0xFD} {`%`_u32(132):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:607.5-607.53 - prod {{0xFD} {`%`_u32(133):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), S_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:608.5-608.53 - prod {{0xFD} {`%`_u32(134):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), U_sx) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:612.5-612.63 - prod {{0xFD} {`%`_u32(135):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:613.5-613.64 - prod {{0xFD} {`%`_u32(136):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:614.5-614.63 - prod {{0xFD} {`%`_u32(137):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:615.5-615.64 - prod {{0xFD} {`%`_u32(138):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:619.5-619.45 - prod {{0xFD} {`%`_u32(139):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:620.5-620.47 - prod {{0xFD} {`%`_u32(140):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:621.5-621.47 - prod {{0xFD} {`%`_u32(141):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:625.5-625.66 - prod {{0xFD} {`%`_u32(156):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:626.5-626.67 - prod {{0xFD} {`%`_u32(157):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:627.5-627.66 - prod {{0xFD} {`%`_u32(158):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:628.5-628.67 - prod {{0xFD} {`%`_u32(159):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:629.5-629.67 - prod {{0xFD} {`%`_u32(274):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:633.5-633.70 - prod {{0xFD} {`%`_u32(126):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:634.5-634.70 - prod {{0xFD} {`%`_u32(127):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:638.5-638.42 - prod {{0xFD} {`%`_u32(160):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:639.5-639.42 - prod {{0xFD} {`%`_u32(161):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:643.5-643.49 - prod {{0xFD} {`%`_u32(163):Bu32}} => VTESTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:647.5-647.41 - prod {{0xFD} {`%`_u32(164):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:651.5-651.63 - prod {{0xFD} {`%`_u32(167):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:652.5-652.64 - prod {{0xFD} {`%`_u32(168):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:653.5-653.63 - prod {{0xFD} {`%`_u32(169):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:654.5-654.64 - prod {{0xFD} {`%`_u32(170):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:658.5-658.45 - prod {{0xFD} {`%`_u32(171):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:659.5-659.49 - prod {{0xFD} {`%`_u32(172):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:660.5-660.49 - prod {{0xFD} {`%`_u32(173):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:664.5-664.43 - prod {{0xFD} {`%`_u32(174):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:665.5-665.43 - prod {{0xFD} {`%`_u32(177):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:666.5-666.43 - prod {{0xFD} {`%`_u32(181):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:667.5-667.45 - prod {{0xFD} {`%`_u32(182):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:668.5-668.45 - prod {{0xFD} {`%`_u32(183):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:669.5-669.45 - prod {{0xFD} {`%`_u32(184):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:670.5-670.45 - prod {{0xFD} {`%`_u32(185):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:674.5-674.59 - prod {{0xFD} {`%`_u32(186):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:675.5-675.66 - prod {{0xFD} {`%`_u32(188):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:676.5-676.67 - prod {{0xFD} {`%`_u32(189):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:677.5-677.66 - prod {{0xFD} {`%`_u32(190):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:678.5-678.67 - prod {{0xFD} {`%`_u32(191):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:682.5-682.72 - prod {{0xFD} {`%`_u32(275):Bu32}} => VEXTTERNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:686.5-686.42 - prod {{0xFD} {`%`_u32(192):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:687.5-687.42 - prod {{0xFD} {`%`_u32(193):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:691.5-691.49 - prod {{0xFD} {`%`_u32(195):Bu32}} => VTESTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:695.5-695.41 - prod {{0xFD} {`%`_u32(196):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:699.5-699.63 - prod {{0xFD} {`%`_u32(199):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:700.5-700.64 - prod {{0xFD} {`%`_u32(200):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:701.5-701.63 - prod {{0xFD} {`%`_u32(201):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:702.5-702.64 - prod {{0xFD} {`%`_u32(202):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:706.5-706.45 - prod {{0xFD} {`%`_u32(203):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:707.5-707.49 - prod {{0xFD} {`%`_u32(204):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:708.5-708.49 - prod {{0xFD} {`%`_u32(205):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:712.5-712.43 - prod {{0xFD} {`%`_u32(206):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:713.5-713.43 - prod {{0xFD} {`%`_u32(209):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:714.5-714.43 - prod {{0xFD} {`%`_u32(213):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:718.5-718.42 - prod {{0xFD} {`%`_u32(214):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:719.5-719.42 - prod {{0xFD} {`%`_u32(215):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:720.5-720.46 - prod {{0xFD} {`%`_u32(216):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:721.5-721.46 - prod {{0xFD} {`%`_u32(217):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:722.5-722.46 - prod {{0xFD} {`%`_u32(218):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:723.5-723.46 - prod {{0xFD} {`%`_u32(219):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:727.5-727.66 - prod {{0xFD} {`%`_u32(220):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:728.5-728.67 - prod {{0xFD} {`%`_u32(221):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:729.5-729.66 - prod {{0xFD} {`%`_u32(222):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:730.5-730.67 - prod {{0xFD} {`%`_u32(223):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:734.5-734.43 - prod {{0xFD} {`%`_u32(103):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:735.5-735.44 - prod {{0xFD} {`%`_u32(104):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:736.5-736.44 - prod {{0xFD} {`%`_u32(105):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:737.5-737.46 - prod {{0xFD} {`%`_u32(106):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:738.5-738.42 - prod {{0xFD} {`%`_u32(224):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:739.5-739.42 - prod {{0xFD} {`%`_u32(225):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:740.5-740.43 - prod {{0xFD} {`%`_u32(227):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:744.5-744.43 - prod {{0xFD} {`%`_u32(228):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:745.5-745.43 - prod {{0xFD} {`%`_u32(229):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:746.5-746.43 - prod {{0xFD} {`%`_u32(230):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:747.5-747.43 - prod {{0xFD} {`%`_u32(231):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:748.5-748.43 - prod {{0xFD} {`%`_u32(232):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:749.5-749.43 - prod {{0xFD} {`%`_u32(233):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:750.5-750.44 - prod {{0xFD} {`%`_u32(234):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:751.5-751.44 - prod {{0xFD} {`%`_u32(235):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:752.5-752.51 - prod {{0xFD} {`%`_u32(269):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:753.5-753.51 - prod {{0xFD} {`%`_u32(270):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:757.5-757.53 - prod {{0xFD} {`%`_u32(261):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:758.5-758.54 - prod {{0xFD} {`%`_u32(262):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:762.5-762.43 - prod {{0xFD} {`%`_u32(116):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:763.5-763.44 - prod {{0xFD} {`%`_u32(117):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:764.5-764.44 - prod {{0xFD} {`%`_u32(122):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:765.5-765.46 - prod {{0xFD} {`%`_u32(148):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:766.5-766.42 - prod {{0xFD} {`%`_u32(236):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:767.5-767.42 - prod {{0xFD} {`%`_u32(237):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:768.5-768.43 - prod {{0xFD} {`%`_u32(239):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:772.5-772.43 - prod {{0xFD} {`%`_u32(240):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:773.5-773.43 - prod {{0xFD} {`%`_u32(241):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:774.5-774.43 - prod {{0xFD} {`%`_u32(242):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:775.5-775.43 - prod {{0xFD} {`%`_u32(243):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:776.5-776.43 - prod {{0xFD} {`%`_u32(244):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:777.5-777.43 - prod {{0xFD} {`%`_u32(245):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:778.5-778.44 - prod {{0xFD} {`%`_u32(246):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:779.5-779.44 - prod {{0xFD} {`%`_u32(247):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:780.5-780.51 - prod {{0xFD} {`%`_u32(271):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:781.5-781.51 - prod {{0xFD} {`%`_u32(272):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:785.5-785.53 - prod {{0xFD} {`%`_u32(263):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:786.5-786.54 - prod {{0xFD} {`%`_u32(264):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:787.5-787.59 - prod {{0xFD} {`%`_u32(265):Bu32}} => VTERNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:788.5-788.59 - prod {{0xFD} {`%`_u32(266):Bu32}} => VTERNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:789.5-789.59 - prod {{0xFD} {`%`_u32(267):Bu32}} => VTERNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:790.5-790.59 - prod {{0xFD} {`%`_u32(268):Bu32}} => VTERNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:794.5-794.61 - prod {{0xFD} {`%`_u32(94):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:795.5-795.61 - prod {{0xFD} {`%`_u32(95):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:796.5-796.62 - prod {{0xFD} {`%`_u32(248):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:797.5-797.62 - prod {{0xFD} {`%`_u32(249):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:798.5-798.60 - prod {{0xFD} {`%`_u32(250):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:799.5-799.60 - prod {{0xFD} {`%`_u32(251):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:800.5-800.67 - prod {{0xFD} {`%`_u32(252):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:801.5-801.67 - prod {{0xFD} {`%`_u32(253):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:802.5-802.64 - prod {{0xFD} {`%`_u32(254):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:803.5-803.64 - prod {{0xFD} {`%`_u32(255):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:804.5-804.66 - prod {{0xFD} {`%`_u32(257):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:805.5-805.66 - prod {{0xFD} {`%`_u32(258):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:806.5-806.71 - prod {{0xFD} {`%`_u32(259):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:807.5-807.71 - prod {{0xFD} {`%`_u32(260):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) -} - -;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec -grammar Bexpr : expr - ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{`in*` : instr*} {{in:Binstr*{in <- `in*`}} {0x0B}} => in*{in <- `in*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bsection_(N : N, syntax en, grammar BX : en*) : en* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`en*` : en*, len : nat} {{`%`_byte(N):Bbyte} {`%`_u32(len):Bu32} {en*{en <- `en*`}:BX}} => en*{en <- `en*`} - -- if (len = 0) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod eps => [] - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bcustom : ()* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod {{Bname} {Bbyte*{}}} => [] - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bcustomsec : () - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod Bsection_(0, syntax (), grammar Bcustom) => ((), ()).1 - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btype : type - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{qt : rectype} qt:Brectype => TYPE_type(qt) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btypesec : type* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`ty*` : type*} ty*{ty <- `ty*`}:Bsection_(1, syntax type, grammar Blist(syntax type, grammar Btype)) => ty*{ty <- `ty*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bimport : import - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{nm_1 : name, nm_2 : name, xt : externtype} {{nm_1:Bname} {nm_2:Bname} {xt:Bexterntype}} => IMPORT_import(nm_1, nm_2, xt) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bimportsec : import* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`im*` : import*} im*{im <- `im*`}:Bsection_(2, syntax import, grammar Blist(syntax import, grammar Bimport)) => im*{im <- `im*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bfuncsec : typeidx* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`x*` : idx*} x*{x <- `x*`}:Bsection_(3, syntax typeidx, grammar Blist(syntax typeidx, grammar Btypeidx)) => x*{x <- `x*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btable : table - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{tt : tabletype, ht : heaptype, at : addrtype, lim : limits} tt:Btabletype => TABLE_table(tt, [`REF.NULL`_instr(ht)]) - -- if (tt = `%%%`_tabletype(at, lim, REF_reftype(?(NULL_null), ht))) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{tt : tabletype, e : expr} {{0x40} {0x00} {tt:Btabletype} {e:Bexpr}} => TABLE_table(tt, e) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btablesec : table* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`tab*` : table*} tab*{tab <- `tab*`}:Bsection_(4, syntax table, grammar Blist(syntax table, grammar Btable)) => tab*{tab <- `tab*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bmem : mem - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{mt : memtype} mt:Bmemtype => MEMORY_mem(mt) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bmemsec : mem* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`mem*` : mem*} mem*{mem <- `mem*`}:Bsection_(5, syntax mem, grammar Blist(syntax mem, grammar Bmem)) => mem*{mem <- `mem*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bglobal : global - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{gt : globaltype, e : expr} {{gt:Bglobaltype} {e:Bexpr}} => GLOBAL_global(gt, e) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bglobalsec : global* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`glob*` : global*} glob*{glob <- `glob*`}:Bsection_(6, syntax global, grammar Blist(syntax global, grammar Bglobal)) => glob*{glob <- `glob*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bexport : export - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{nm : name, xx : externidx} {{nm:Bname} {xx:Bexternidx}} => EXPORT_export(nm, xx) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bexportsec : export* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`ex*` : export*} ex*{ex <- `ex*`}:Bsection_(7, syntax export, grammar Blist(syntax export, grammar Bexport)) => ex*{ex <- `ex*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bstart : start* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{x : idx} x:Bfuncidx => [START_start(x)] - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bstartsec : start? - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{startopt : startopt} startopt:Bsection_(8, syntax start, grammar Bstart) => !($opt_(syntax start, startopt)) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Belemkind : reftype - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod 0x00 => REF_reftype(?(), FUNC_heaptype) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Belem : elem - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`y*` : idx*, e_o : expr} {{`%`_u32(0):Bu32} {e_o:Bexpr} {y*{y <- `y*`}:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(REF_reftype(?(), FUNC_heaptype), [`REF.FUNC`_instr(y)*{y <- `y*`}], ACTIVE_elemmode(`%`_tableidx(0), e_o)) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `y*` : idx*} {{`%`_u32(1):Bu32} {rt:Belemkind} {y*{y <- `y*`}:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- `y*`}], PASSIVE_elemmode) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `y*` : idx*, x : idx, e : expr} {{`%`_u32(2):Bu32} {x:Btableidx} {e:Bexpr} {rt:Belemkind} {y*{y <- `y*`}:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- `y*`}], ACTIVE_elemmode(x, e)) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `y*` : idx*} {{`%`_u32(3):Bu32} {rt:Belemkind} {y*{y <- `y*`}:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- `y*`}], DECLARE_elemmode) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`e*` : expr*, e_O : expr} {{`%`_u32(4):Bu32} {e_O:Bexpr} {e*{e <- `e*`}:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(REF_reftype(?(NULL_null), FUNC_heaptype), e*{e <- `e*`}, ACTIVE_elemmode(`%`_tableidx(0), e_O)) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `e*` : expr*} {{`%`_u32(5):Bu32} {rt:Breftype} {e*{e <- `e*`}:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e*{e <- `e*`}, PASSIVE_elemmode) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `e*` : expr*, x : idx, e_O : expr} {{`%`_u32(6):Bu32} {x:Btableidx} {e_O:Bexpr} {rt:Breftype} {e*{e <- `e*`}:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e*{e <- `e*`}, ACTIVE_elemmode(x, e_O)) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, `e*` : expr*} {{`%`_u32(7):Bu32} {rt:Breftype} {e*{e <- `e*`}:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e*{e <- `e*`}, DECLARE_elemmode) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Belemsec : elem* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`elem*` : elem*} elem*{elem <- `elem*`}:Bsection_(9, syntax elem, grammar Blist(syntax elem, grammar Belem)) => elem*{elem <- `elem*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Blocals : local* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{t : valtype, n : n} {{`%`_u32(n):Bu32} {t:Bvaltype}} => LOCAL_local(t)^n{} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bfunc : code - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`loc**` : local**, e : expr} {{loc*{loc <- `loc*`}*{`loc*` <- `loc**`}:Blist(syntax local*, grammar Blocals)} {e:Bexpr}} => ($concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e) - -- if (|$concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`})| < (2 ^ 32)) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bcode : code - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{code : code, len : nat} {{`%`_u32(len):Bu32} {code:Bfunc}} => code - -- if (len = 0) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bcodesec : code* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`code*` : code*} code*{code <- `code*`}:Bsection_(10, syntax code, grammar Blist(syntax code, grammar Bcode)) => code*{code <- `code*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bdata : data - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`b*` : byte*, e : expr} {{`%`_u32(0):Bu32} {e:Bexpr} {b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b*{b <- `b*`}, ACTIVE_datamode(`%`_memidx(0), e)) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`b*` : byte*} {{`%`_u32(1):Bu32} {b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b*{b <- `b*`}, PASSIVE_datamode) - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`b*` : byte*, x : idx, e : expr} {{`%`_u32(2):Bu32} {x:Bmemidx} {e:Bexpr} {b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b*{b <- `b*`}, ACTIVE_datamode(x, e)) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bdatasec : data* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`data*` : data*} data*{data <- `data*`}:Bsection_(11, syntax data, grammar Blist(syntax data, grammar Bdata)) => data*{data <- `data*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bdatacnt : u32* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{n : n} `%`_u32(n):Bu32 => [`%`_u32(n)] - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bdatacntsec : u32? - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{nopt : nopt} nopt:Bsection_(12, syntax u32, grammar Bdatacnt) => !($opt_(syntax u32, nopt)) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btag : tag - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{jt : tagtype} jt:Btagtype => TAG_tag(jt) - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Btagsec : tag* - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`tag*` : tag*} tag*{tag <- `tag*`}:Bsection_(13, syntax tag, grammar Blist(syntax tag, grammar Btag)) => tag*{tag <- `tag*`} - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bmagic : () - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod {{0x00} {0x61} {0x73} {0x6D}} => ((), ()).1 - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bversion : () - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod {{0x01} {0x00} {0x00} {0x00}} => ((), ()).1 - -;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec -grammar Bmodule : module - ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) - -- (if (n = |data*{data <- `data*`}|))?{n <- `n?`} - -- if ((n?{n <- `n?`} =/= ?()) \/ ($dataidx_funcs(func*{func <- `func*`}) = [])) - -- (if (func = FUNC_func(typeidx, local*{local <- `local*`}, expr)))*{expr <- `expr*`, func <- `func*`, `local*` <- `local**`, typeidx <- `typeidx*`} - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tchar : char - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:(0x00 | ... | 0xD7FF) => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:(0xE000 | ... | 0x10FFFF) => `%`_char(``) - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tsource : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : char} [``]:Tchar*{} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar TuNplain : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:eps => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar TsNplain : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:eps => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar TfNplain : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:eps => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tidchar : char - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x30 | ... | 0x39) => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x41 | ... | 0x5A) => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x61 | ... | 0x7A) => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x21 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x23 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x24 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x25 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x26 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x27 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2A => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2B => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2D => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2E => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2F => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3A => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3C => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3D => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3E => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3F => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x40 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5C => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5E => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5F => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x60 => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x7C => `%`_char(``) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x7E => `%`_char(``) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tdigit : nat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x30 => 0 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x31 => 1 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x32 => 2 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x33 => 3 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x34 => 4 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x35 => 5 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x36 => 6 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x37 => 7 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x38 => 8 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x39 => 9 - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Thexdigit : nat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{d : nat} d:Tdigit => d - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x41 => 10 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x42 => 11 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x43 => 12 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x44 => 13 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x45 => 14 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x46 => 15 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x61 => 10 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x62 => 11 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x63 => 12 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x64 => 13 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x65 => 14 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod 0x66 => 15 - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:22.1-24.46 -grammar Thexnum : nat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:23.5-23.21 - prod{h : nat} h:Thexdigit => h - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:24.5-24.46 - prod{n : n, h : nat} {{n:Thexnum} {"_"?{}} {h:Thexdigit}} => ((16 * n) + h) -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tstringchar : char - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tchar => c - -- if ((((c!`%`_char.0 >= 32) /\ (c!`%`_char.0 =/= 127)) /\ (c =/= `%`_char(34))) /\ (c =/= `%`_char(92))) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\t" => `%`_char(9) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\n" => `%`_char(10) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\r" => `%`_char(13) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\\"" => `%`_char(34) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\'" => `%`_char(39) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\\\" => `%`_char(92) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n} {{"\\u{"} {n:Thexnum} {"}"}} => `%`_char(n) - -- if ((n < 55296) \/ ((59392 <= n) /\ (n < 1114112))) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tstringelem : byte* - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tstringchar => $utf8([c]) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [`%`_byte(((16 * h_1) + h_2))] - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tstring : byte* - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`b**` : byte**} {{"\""} {b*{b <- `b*`}:Tstringelem*{`b*` <- `b**`}} {"\""}} => $concat_(syntax byte, b*{b <- `b*`}*{`b*` <- `b**`}) - -- if (|$concat_(syntax byte, b*{b <- `b*`}*{`b*` <- `b**`})| < (2 ^ 32)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tname : name - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*, `b*` : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) - -- if (b*{b <- `b*`} = $utf8(c*{c <- `c*`})) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tid : name - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*} {{"$"} {c*{c <- `c*`}:Tidchar+{}}} => `%`_name(c*{c <- `c*`}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*} {{"$"} {`%`_name(c*{c <- `c*`}):Tname}} => `%`_name(c*{c <- `c*`}) - -- if (|c*{c <- `c*`}| > 0) - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tkeyword : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:{{(0x61 | ... | 0x7A)} {Tidchar*{}}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Treserved : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} [``]:{{Tidchar} {Tstring} {","} {";"} {"["} {"]"} {"{"} {"}"}}+{} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Ttoken : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:Tkeyword => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:TuNplain => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:TsNplain => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:TfNplain => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : byte} [``]:Tstring => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : name} ``:Tid => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:0x28 => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:0x29 => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:Treserved => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tannotid : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : char} [``]:Tidchar+{} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : name} ``:Tname => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:56.1-57.26 -grammar Tblockcomment : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:57.5-57.26 - prod{`` : ()} ``:{{"(;"} {Tblockchar*{}} {";)"}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:60.1-64.18 -grammar Tblockchar : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:61.5-61.47 - prod{`` : char, c : char} ``:c:Tchar => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(40))) - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:62.5-62.47 - prod{`` : (), c : char} ``:{{";"+{}} {c:Tchar}} => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(41))) - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:63.5-63.47 - prod{`` : (), c : char} ``:{{"("+{}} {c:Tchar}} => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(40))) - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:64.5-64.18 - prod{`` : ()} ``:Tblockcomment => (``, ()).1 -} - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Teof : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : text} ``:"" => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tlinechar : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : char, c : char} ``:c:Tchar => (``, ()).1 - -- if ((c!`%`_char.0 =/= 10) /\ (c!`%`_char.0 =/= 13)) - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tnewline : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:0x0A => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:0x0D => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:{{0x0D} {0x0A}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tlinecomment : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:{{";;"} {Tlinechar*{}} {Tnewline Teof}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tcomment : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:Tlinecomment => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:Tblockcomment => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -grammar Tformat : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : ()} ``:Tnewline => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:0x09 => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:32.1-33.41 -grammar Tspace : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:33.5-33.41 - prod{`` : ()} [``]:{{" "} Tformat Tcomment Tannot}*{} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:69.1-70.41 -grammar Tannot : () - ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:70.5-70.41 - prod{`` : ()} ``:{{"(@"} Tannotid {{Tspace Ttoken}*{}} {")"}} => (``, ()).1 -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tsign : int - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod eps => + (1 : nat <:> int) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "+" => + (1 : nat <:> int) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "-" => - (1 : nat <:> int) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:18.1-20.40 -grammar Tnum : nat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:19.5-19.18 - prod{d : nat} d:Tdigit => d - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:20.5-20.40 - prod{n : n, d : nat} {{n:Tnum} {"_"?{}} {d:Tdigit}} => ((10 * n) + d) -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar TuN(N : N) : uN - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n} n:Tnum => `%`_uN(n) - -- if (n < (2 ^ N)) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n} {{"0x"} {n:Thexnum}} => `%`_uN(n) - -- if (n < (2 ^ N)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar TsN(N : N) : sN - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{s : int, n : n} {{s:Tsign} {`%`_uN(n):TuN(N)}} => `%`_sN((s * (n : nat <:> int))) - -- if ((- ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= (s * (n : nat <:> int))) /\ ((s * (n : nat <:> int)) < ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar TiN(N : N) : iN - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n} `%`_uN(n):TuN(N) => `%`_iN(n) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{i : sN} i:TsN(N) => `%`_iN($inv_signed_(N, i!`%`_sN.0)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:38.1-40.48 -grammar Tfrac : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:39.5-39.26 - prod{d : nat} d:Tdigit => ((d : nat <:> rat) / (10 : nat <:> rat)) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:40.5-40.48 - prod{d : nat, p : rat} {{d:Tdigit} {"_"?{}} {p:Tfrac}} => (((d + ((p / (10 : nat <:> rat)) : rat <:> nat)) : nat <:> rat) / (10 : nat <:> rat)) -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:42.1-44.54 -grammar Thexfrac : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:43.5-43.29 - prod{h : nat} h:Thexdigit => ((h : nat <:> rat) / (16 : nat <:> rat)) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:44.5-44.54 - prod{h : nat, p : rat} {{h:Thexdigit} {"_"?{}} {p:Thexfrac}} => (((h + ((p / (16 : nat <:> rat)) : rat <:> nat)) : nat <:> rat) / (16 : nat <:> rat)) -} - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tmant : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : nat} {{p:Tnum} {"."?{}}} => (p : nat <:> rat) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : nat, q : rat} {{p:Tnum} {"."} {q:Tfrac}} => ((p + (q : rat <:> nat)) : nat <:> rat) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Thexmant : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : nat} {{p:Thexnum} {"."?{}}} => (p : nat <:> rat) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : nat, q : rat} {{p:Thexnum} {"."} {q:Thexfrac}} => ((p + (q : rat <:> nat)) : nat <:> rat) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tfloat : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : rat, s : int, ee : nat} {{p:Tmant} {{"E"} {"e"}} {s:Tsign} {ee:Tnum}} => (p * ((10 ^ ((s * (ee : nat <:> int)) : int <:> nat)) : nat <:> rat)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Thexfloat : rat - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{p : rat, s : int, ee : nat} {{"0x"} {p:Thexmant} {{"P"} {"p"}} {s:Tsign} {ee:Tnum}} => (p * ((2 ^ ((s * (ee : nat <:> int)) : int <:> nat)) : nat <:> rat)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar TfNmag(N : N) : fNmag - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{q : rat} q:Tfloat => $ieee_(N, q) - -- if ($ieee_(N, q) =/= INF_fNmag) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{q : rat} q:Thexfloat => $ieee_(N, q) - -- if ($ieee_(N, q) =/= INF_fNmag) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "inf" => INF_fNmag - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "nan" => NAN_fNmag($canon_(N)) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) - -- if ((1 <= n) /\ (n < (2 ^ !($signif(N))))) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar TfN(N : N) : fN - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{q : fNmag} {{+ (1 : nat <:> int):Tsign} {q:TfNmag(N)}} => POS_fN(q) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{q : fNmag} {{- (1 : nat <:> int):Tsign} {q:TfNmag(N)}} => NEG_fN(q) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tu8 : u8 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : uN} ``:TuN(8) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tu32 : u32 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : uN} ``:TuN(32) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tu64 : u64 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : uN} ``:TuN(64) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ti8 : u8 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : iN} ``:TiN(8) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ti16 : u16 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : iN} ``:TiN(16) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ti32 : u32 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : iN} ``:TiN(32) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ti64 : u64 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : iN} ``:TiN(64) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tf32 : f32 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : fN} ``:TfN(32) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tf64 : f64 - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : fN} ``:TfN(64) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tlist(syntax el, grammar TX : el) : el* - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`el*` : el*} el:TX*{el <- `el*`} => el*{el <- `el*`} - -- if (|el*{el <- `el*`}| < (2 ^ 32)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tidx_(ids : name?*) : idx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} x:Tu32 => x - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx, id : name} id:Tid => x - -- if (ids[x!`%`_uN.0] = ?(id)) - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ttypeidx_(I : I) : typeidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.TYPES_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ttagidx_(I : I) : tagidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.TAGS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tglobalidx_(I : I) : globalidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.GLOBALS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tmemidx_(I : I) : memidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.MEMS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Ttableidx_(I : I) : tableidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.TABLES_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tfuncidx_(I : I) : funcidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.FUNCS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tdataidx_(I : I) : dataidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.DATAS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Telemidx_(I : I) : elemidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.ELEMS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tlocalidx_(I : I) : localidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.LOCALS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tlabelidx_(I : I) : labelidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.LABELS_I) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Tfieldidx__(I : I, x : idx) : fieldidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.FIELDS_I[x!`%`_uN.0]) => `` - -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec -grammar Texternidx_(I : I) : externidx - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} {{"("} {"tag"} {x:Ttagidx_(I)} {")"}} => TAG_externidx(x) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} {{"("} {"global"} {x:Tglobalidx_(I)} {")"}} => GLOBAL_externidx(x) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} {{"("} {"memory"} {x:Tmemidx_(I)} {")"}} => MEM_externidx(x) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} {{"("} {"table"} {x:Ttableidx_(I)} {")"}} => TABLE_externidx(x) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{x : idx} {{"("} {"func"} {x:Tfuncidx_(I)} {")"}} => FUNC_externidx(x) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tnumtype : numtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i32" => I32_numtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i64" => I64_numtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "f32" => F32_numtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "f64" => F64_numtype - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tvectype : vectype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "v128" => V128_vectype - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tabsheaptype : heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "any" => ANY_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "eq" => EQ_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i31" => I31_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "struct" => STRUCT_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "array" => ARRAY_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "none" => NONE_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "func" => FUNC_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "nofunc" => NOFUNC_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "exn" => EXN_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "noexn" => NOEXN_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "extern" => EXTERN_heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "noextern" => NOEXTERN_heaptype - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Theaptype_(I : I) : heaptype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ht : heaptype} ht:Tabsheaptype => ht - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx} x:Ttypeidx_(I) => _IDX_heaptype(x) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tnull : null - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "null" => NULL_null - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Treftype_(I : I) : reftype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`null?` : null?, ht : heaptype} {{"("} {"ref"} {null?{null <- `null?`}:Tnull?{}} {ht:Theaptype_(I)} {")"}} => REF_reftype(null?{null <- `null?`}, ht) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tvaltype_(I : I) : valtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{nt : numtype} nt:Tnumtype => (nt : numtype <: valtype) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{vt : vectype} vt:Tvectype => (vt : vectype <: valtype) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{rt : reftype} rt:Treftype_(I) => (rt : reftype <: valtype) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tpacktype : packtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i8" => I8_packtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i16" => I16_packtype - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tstoragetype_(I : I) : storagetype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} t:Tvaltype_(I) => (t : valtype <: storagetype) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{pt : packtype} pt:Tpacktype => (pt : packtype <: storagetype) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tfieldtype_(I : I) : fieldtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{zt : storagetype} zt:Tstoragetype_(I) => `%%`_fieldtype(?(), zt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{zt : storagetype} {{"("} {"mut"} {zt:Tstoragetype_(I)} {")"}} => `%%`_fieldtype(?(MUT_mut), zt) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tfield_(I : I) : (fieldtype, name?) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ft : fieldtype, `id?` : char?} {{"("} {"field"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {ft:Tfieldtype_(I)} {")"}} => (ft, ?(`%`_name(lift(id?{id <- `id?`})))) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tparam_(I : I) : (valtype, name?) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype, `id?` : char?} {{"("} {"param"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {t:Tvaltype_(I)} {")"}} => (t, ?(`%`_name(lift(id?{id <- `id?`})))) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tresult_(I : I) : valtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} {{"("} {"result"} {t:Tvaltype_(I)} {")"}} => t - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tcomptype_(I : I) : (comptype, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`ft*` : fieldtype*, `id?*` : char?*} {{"("} {"struct"} {(ft, ?(`%`_name(lift(id?{id <- `id?`}))))*{ft <- `ft*`, `id?` <- `id?*`}:Tlist(syntax (fieldtype, name?), grammar Tfield_(I))} {")"}} => (STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [?(`%`_name(lift(id?{id <- `id?`})))*{`id?` <- `id?*`}], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ft : fieldtype} {{"("} {"array"} {ft:Tfieldtype_(I)} {")"}} => (ARRAY_comptype(ft), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(`%`_name([]))]], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`t_1*` : valtype*, `t_2*` : valtype*, `id?*` : char?*} {{"("} {"func"} {(t_1, ?(`%`_name(lift(id?{id <- `id?`}))))*{`id?` <- `id?*`, t_1 <- `t_1*`}:Tlist(syntax (valtype, name?), grammar Tparam_(I))} {t_2*{t_2 <- `t_2*`}:Tlist(syntax valtype, grammar Tresult_(I))} {")"}} => (`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(`%`_name([]))]], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tfinal : final - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "final" => FINAL_final - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tsubtype_(I : I) : (subtype, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`fin?` : final?, `x*` : idx*, ct : comptype, I' : I} {{"("} {"sub"} {fin?{fin <- `fin?`}:Tfinal?{}} {x*{x <- `x*`}:Tlist(syntax typeidx, grammar Ttypeidx_(I))} {(ct, I'):Tcomptype_(I)} {")"}} => (SUB_subtype(fin?{fin <- `fin?`}, _IDX_typeuse(x)*{x <- `x*`}, ct), I') - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Ttypedef_(I : I) : (subtype, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{st : subtype, I' : I, `id?` : char?} {{"("} {"type"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(st, I'):Tsubtype_(I)} {")"}} => (st, I' +++ {TYPES [?(`%`_name(lift(id?{id <- `id?`})))], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Trectype_(I : I) : (rectype, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`st*` : subtype*, `I'*` : I*} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), $concat_idctxt(I'*{I' <- `I'*`})) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Taddrtype : addrtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i32" => I32_addrtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod "i64" => I64_addrtype - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tlimits : limits - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{n : n} `%`_u64(n):Tu64 => `[%..%]`_limits(`%`_u64(n), ?()) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{n : n, m : m} {{`%`_u64(n):Tu64} {`%`_u64(m):Tu64}} => `[%..%]`_limits(`%`_u64(n), ?(`%`_u64(m))) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Ttypeuse_(I : I) : (typeidx, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, I' : I, `st*` : subtype*, i : n, `t_1*` : valtype*, `t_2*` : valtype*} {{"("} {"type"} {x:Ttypeidx_(I)} {")"}} => (x, I') - -- if (I.TYPEDEFS_I[x!`%`_uN.0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) - -- if (st*{st <- `st*`}[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))^|t_1*{t_1 <- `t_1*`}|{}, LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, I' : I, `id?*` : char?*, `t_1*` : valtype*, `t_2*` : valtype*, `st*` : subtype*, i : n} {{"("} {"type"} {x:Ttypeidx_(I)} {")"} {(t_1, ?(`%`_name(lift(id?{id <- `id?`}))))*{`id?` <- `id?*`, t_1 <- `t_1*`}:Tparam_(I)*{}} {t_2*{t_2 <- `t_2*`}:Tresult_(I)*{}}} => (x, I') - -- if (I.TYPEDEFS_I[x!`%`_uN.0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) - -- if (st*{st <- `st*`}[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name(lift(id?{id <- `id?`})))*{`id?` <- `id?*`}, LABELS [], FIELDS [], TYPEDEFS []}) - -- Idctxt_ok: `|-%:OK`(I') - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Ttagtype_(I : I) : tagtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_tagtype(x) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tglobaltype_(I : I) : globaltype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} t:Tvaltype_(I) => `%%`_globaltype(?(), t) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} {{"("} {"mut"} {t:Tvaltype_(I)} {")"}} => `%%`_globaltype(?(MUT_mut), t) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Tmemtype_(I : I) : memtype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{at : addrtype, lim : limits} {{at:Taddrtype} {lim:Tlimits}} => `%%PAGE`_memtype(at, lim) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Ttabletype_(I : I) : tabletype - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{at : addrtype, lim : limits, rt : reftype} {{at:Taddrtype} {lim:Tlimits} {rt:Treftype_(I)}} => `%%%`_tabletype(at, lim, rt) - -;; ../../../../specification/wasm-3.0/6.2-text.types.spectec -grammar Texterntype_(I : I) : (externtype, idctxt) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{jt : tagtype, `id?` : char?} {{"("} {"tag"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {jt:Ttagtype_(I)} {")"}} => (TAG_externtype(jt), {TYPES [], TAGS [?(`%`_name(lift(id?{id <- `id?`})))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{gt : globaltype, `id?` : char?} {{"("} {"global"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {gt:Tglobaltype_(I)} {")"}} => (GLOBAL_externtype(gt), {TYPES [], TAGS [], GLOBALS [?(`%`_name(lift(id?{id <- `id?`})))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{mt : memtype, `id?` : char?} {{"("} {"memory"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {mt:Tmemtype_(I)} {")"}} => (MEM_externtype(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(`%`_name(lift(id?{id <- `id?`})))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{tt : tabletype, `id?` : char?} {{"("} {"table"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {tt:Ttabletype_(I)} {")"}} => (TABLE_externtype(tt), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(`%`_name(lift(id?{id <- `id?`})))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, `id?` : char?, I' : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I'):Ttypeuse_(I)} {")"}} => (FUNC_externtype(_IDX_typeuse(x)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tlabel_(I : I) : (name?, I) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod eps => (?(), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} +++ I) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{id : name} id:Tid => (?(id), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [?(id)], FIELDS [], TYPEDEFS []} +++ I) - -- if ~ (?(id) <- I.LABELS_I) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{id : name, x : idx} id:Tid => (?(id), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [?(id)], FIELDS [], TYPEDEFS []} +++ I[LABELS_I[x!`%`_uN.0] = ?()]) - -- if (?(id) = I.LABELS_I[x!`%`_uN.0]) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tblocktype_(I : I) : blocktype - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tcatch_(I : I) : catch - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, l : labelidx} {{"("} {"catch"} {x:Ttagidx_(I)} {l:Tlabelidx_(I)} {")"}} => CATCH_catch(x, l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, l : labelidx} {{"("} {"catch_ref"} {x:Ttagidx_(I)} {l:Tlabelidx_(I)} {")"}} => CATCH_REF_catch(x, l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"("} {"catch_all"} {l:Tlabelidx_(I)} {")"}} => CATCH_ALL_catch(l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"("} {"catch_all_ref"} {l:Tlabelidx_(I)} {")"}} => CATCH_ALL_REF_catch(l) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tfoldedinstr_(I : I) : instr* - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tlaneidx : laneidx - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : u8} i:Tu8 => i - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Talign_(N : N) : u32 - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{n : n, m : m} {{"align="} {`%`_u64(m):Tu64}} => `%`_u32(n) - -- if (m = (2 ^ n)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod eps => `%`_u32(N) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Toffset : u64 - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{m : m} {{"offset="} {`%`_u64(m):Tu64}} => `%`_u64(m) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod eps => `%`_u64(0) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tmemarg_(N : N) : memarg - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{n : n, m : m} {{`%`_u32(n):Talign_(N)} {`%`_u64(m):Toffset}} => {ALIGN `%`_u32(n), OFFSET `%`_u64(m)} - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Tplaininstr_(I : I) : instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "unreachable" => UNREACHABLE_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "nop" => NOP_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "drop" => DROP_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`t*?` : valtype*?} {{"select"} {t*{t <- `t*`}:Tresult_(I)*{}?{`t*` <- `t*?`}}} => SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`}) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"br"} {l:Tlabelidx_(I)}} => BR_instr(l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"br_if"} {l:Tlabelidx_(I)}} => BR_IF_instr(l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`l*` : labelidx*, l' : labelidx} {{"br_table"} {l*{l <- `l*`}:Tlabelidx_(I)*{}} {l':Tlabelidx_(I)}} => BR_TABLE_instr(l*{l <- `l*`}, l') - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"br_on_null"} {l:Tlabelidx_(I)}} => BR_ON_NULL_instr(l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx} {{"br_on_non_null"} {l:Tlabelidx_(I)}} => BR_ON_NON_NULL_instr(l) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx, rt_1 : reftype, rt_2 : reftype} {{"br_on_cast"} {l:Tlabelidx_(I)} {rt_1:Treftype_(I)} {rt_2:Treftype_(I)}} => BR_ON_CAST_instr(l, rt_1, rt_2) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{l : labelidx, rt_1 : reftype, rt_2 : reftype} {{"br_on_cast_fail"} {l:Tlabelidx_(I)} {rt_1:Treftype_(I)} {rt_2:Treftype_(I)}} => BR_ON_CAST_FAIL_instr(l, rt_1, rt_2) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"call"} {x:Tfuncidx_(I)}} => CALL_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "return" => RETURN_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"return_call"} {x:Tfuncidx_(I)}} => RETURN_CALL_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "throw_ref" => THROW_REF_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.get"} {x:Tlocalidx_(I)}} => `LOCAL.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.set"} {x:Tlocalidx_(I)}} => `LOCAL.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.tee"} {x:Tlocalidx_(I)}} => `LOCAL.TEE`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"global.get"} {x:Tglobalidx_(I)}} => `GLOBAL.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"global.set"} {x:Tglobalidx_(I)}} => `GLOBAL.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.get"} {x:Ttableidx_(I)}} => `TABLE.GET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.set"} {x:Ttableidx_(I)}} => `TABLE.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.size"} {x:Ttableidx_(I)}} => `TABLE.SIZE`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.grow"} {x:Ttableidx_(I)}} => `TABLE.GROW`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.fill"} {x:Ttableidx_(I)}} => `TABLE.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"table.copy"} {x_1:Ttableidx_(I)} {x_2:Ttableidx_(I)}} => `TABLE.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"table.init"} {x:Ttableidx_(I)} {y:Telemidx_(I)}} => `TABLE.INIT`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"elem.drop"} {x:Telemidx_(I)}} => `ELEM.DROP`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => LOAD_instr(I32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => LOAD_instr(I64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"f32.load"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => LOAD_instr(F32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"f64.load"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => LOAD_instr(F64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load8_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load8_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load16_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load16_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load8_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load8_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load16_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load16_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load32_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), S_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load32_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), U_sx))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load"} {x:Tmemidx_(I)} {ao:Tmemarg_(16)}} => VLOAD_instr(V128_vectype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8x8_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8x8_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16x4_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16x4_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32x2_s"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, S_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32x2_u"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, U_sx)), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8_splat"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(8))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16_splat"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(16))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32_splat"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(32))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load64_splat"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(64))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32_zero"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(32))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load64_zero"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(64))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load8_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load16_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load32_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load64_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.store"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => STORE_instr(I32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => STORE_instr(I64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"f32.store"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => STORE_instr(F32_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"f64.store"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)}} => STORE_instr(F64_numtype, ?(), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.store8"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.store16"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store8"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store16"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store32"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(32)))), x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.store"} {x:Tmemidx_(I)} {ao:Tmemarg_(16)}} => VSTORE_instr(V128_vectype, x, ao) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store8_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store16_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store32_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store64_lane"} {x:Tmemidx_(I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.size"} {x:Tmemidx_(I)}} => `MEMORY.SIZE`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.grow"} {x:Tmemidx_(I)}} => `MEMORY.GROW`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.fill"} {x:Tmemidx_(I)}} => `MEMORY.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"memory.copy"} {x_1:Tmemidx_(I)} {x_2:Tmemidx_(I)}} => `MEMORY.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"memory.init"} {x:Tmemidx_(I)} {y:Tdataidx_(I)}} => `MEMORY.INIT`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"data.drop"} {x:Tdataidx_(I)}} => `DATA.DROP`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{ht : heaptype} {{"ref.null"} {ht:Theaptype_(I)}} => `REF.NULL`_instr(ht) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"ref.func"} {x:Tfuncidx_(I)}} => `REF.FUNC`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.is_null" => `REF.IS_NULL`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.as_non_null" => `REF.AS_NON_NULL`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.eq" => `REF.EQ`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{rt : reftype} {{"ref.test"} {rt:Treftype_(I)}} => `REF.TEST`_instr(rt) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{rt : reftype} {{"ref.cast"} {rt:Treftype_(I)}} => `REF.CAST`_instr(rt) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.i31" => `REF.I31`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i31.get_s" => `I31.GET`_instr(S_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i31.get_u" => `I31.GET`_instr(U_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"struct.new"} {x:Ttypeidx_(I)}} => `STRUCT.NEW`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"struct.new_default"} {x:Ttypeidx_(I)}} => `STRUCT.NEW_DEFAULT`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get"} {x:Ttypeidx_(I)} {i:Tfieldidx__(I, x)}} => `STRUCT.GET`_instr(?(), x, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get_s"} {x:Ttypeidx_(I)} {i:Tfieldidx__(I, x)}} => `STRUCT.GET`_instr(?(S_sx), x, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get_u"} {x:Ttypeidx_(I)} {i:Tfieldidx__(I, x)}} => `STRUCT.GET`_instr(?(U_sx), x, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.set"} {x:Ttypeidx_(I)} {i:Tfieldidx__(I, x)}} => `STRUCT.SET`_instr(x, i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.new"} {x:Ttypeidx_(I)}} => `ARRAY.NEW`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.new_default"} {x:Ttypeidx_(I)}} => `ARRAY.NEW_DEFAULT`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, n : n} {{"array.new_fixed"} {x:Ttypeidx_(I)} {`%`_u32(n):Tu32}} => `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.new_data"} {x:Ttypeidx_(I)} {y:Tdataidx_(I)}} => `ARRAY.NEW_DATA`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.new_elem"} {x:Ttypeidx_(I)} {y:Telemidx_(I)}} => `ARRAY.NEW_ELEM`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get"} {x:Ttypeidx_(I)}} => `ARRAY.GET`_instr(?(), x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get_s"} {x:Ttypeidx_(I)}} => `ARRAY.GET`_instr(?(S_sx), x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get_u"} {x:Ttypeidx_(I)}} => `ARRAY.GET`_instr(?(U_sx), x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.set"} {x:Ttypeidx_(I)}} => `ARRAY.SET`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "array.len" => `ARRAY.LEN`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.fill"} {x:Ttypeidx_(I)}} => `ARRAY.FILL`_instr(x) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"array.copy"} {x_1:Ttypeidx_(I)} {x_2:Ttypeidx_(I)}} => `ARRAY.COPY`_instr(x_1, x_2) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.init_data"} {x:Ttypeidx_(I)} {y:Tdataidx_(I)}} => `ARRAY.INIT_DATA`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.init_elem"} {x:Ttypeidx_(I)} {y:Telemidx_(I)}} => `ARRAY.INIT_ELEM`_instr(x, y) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "any.convert_extern" => `ANY.CONVERT_EXTERN`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "extern.convert_any" => `EXTERN.CONVERT_ANY`_instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{c : u32} {{"i32.const"} {c:Ti32}} => CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, c)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{c : u64} {{"i64.const"} {c:Ti64}} => CONST_instr(I64_numtype, mk_num__0_num_(I64_Inn, c)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{c : f32} {{"f32.const"} {c:Tf32}} => CONST_instr(F32_numtype, mk_num__1_num_(F32_Fnn, c)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{c : f64} {{"f64.const"} {c:Tf64}} => CONST_instr(F64_numtype, mk_num__1_num_(F64_Fnn, c)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.eqz" => TESTOP_instr(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.eqz" => TESTOP_instr(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.eq" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, EQ_relop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.ne" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, NE_relop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.lt_s" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.lt_u" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.gt_s" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.gt_u" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.le_s" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.le_u" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.ge_s" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.ge_u" => RELOP_instr(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.eq" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, EQ_relop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.ne" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, NE_relop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.lt_s" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.lt_u" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.gt_s" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.gt_u" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.le_s" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.le_u" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.ge_s" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.ge_u" => RELOP_instr(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.eq" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, EQ_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.ne" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, NE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.lt" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, LT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.gt" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, GT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.le" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, LE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.ge" => RELOP_instr(F32_numtype, mk_relop__1_relop_(F32_Fnn, GE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.eq" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, EQ_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.ne" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, NE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.lt" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, LT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.gt" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, GT_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.le" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, LE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.ge" => RELOP_instr(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.clz" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.ctz" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.popcnt" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.extend8_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(8)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.extend16_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(16)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.clz" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.ctz" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.popcnt" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend8_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(8)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend16_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(16)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend32_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(32)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.abs" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.neg" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.sqrt" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.ceil" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.floor" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.trunc" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.nearest" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.abs" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.neg" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.sqrt" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.ceil" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.floor" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.trunc" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.nearest" => UNOP_instr(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.add" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.sub" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.mul" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.div_s" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.div_u" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.rem_s" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.rem_u" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.and" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.or" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.xor" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.shl" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.shr_s" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.shr_u" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.rotl" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.rotr" => BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.add" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.sub" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.mul" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.div_s" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.div_u" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.rem_s" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.rem_u" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.and" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.or" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.xor" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.shl" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.shr_s" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.shr_u" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.rotl" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.rotr" => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.add" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.sub" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.mul" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.div" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.min" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.max" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.copysign" => BINOP_instr(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.add" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.sub" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.mul" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.div" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.min" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.max" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.copysign" => BINOP_instr(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.wrap_i64" => CVTOP_instr(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_f32_s" => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_f32_u" => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_f64_s" => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_f64_u" => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_sat_f32_s" => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_sat_f32_u" => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_sat_f64_s" => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.trunc_sat_f64_u" => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend_i32_s" => CVTOP_instr(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend_i32_u" => CVTOP_instr(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_f32_s" => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_f32_u" => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_f64_s" => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_f64_u" => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_sat_f32_s" => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_sat_f32_u" => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_sat_f64_s" => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.trunc_sat_f64_u" => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.demote_f64" => CVTOP_instr(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.convert_i32_s" => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.convert_i32_u" => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.convert_i64_s" => CVTOP_instr(F32_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.convert_i64_u" => CVTOP_instr(F32_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.promote_f32" => CVTOP_instr(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.convert_i32_s" => CVTOP_instr(F64_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.convert_i32_u" => CVTOP_instr(F64_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.convert_i64_s" => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.convert_i64_u" => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.reinterpret_f32" => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.reinterpret_f64" => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32.reinterpret_i32" => CVTOP_instr(F32_numtype, I32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64.reinterpret_i64" => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : u8*} {{"v128.const"} {"i8x16"} {c*{c <- `c*`}:Ti8^16{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $ibytes_(8, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : u16*} {{"v128.const"} {"i16x8"} {c*{c <- `c*`}:Ti16^8{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $ibytes_(16, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : u32*} {{"v128.const"} {"i32x4"} {c*{c <- `c*`}:Ti32^4{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $ibytes_(32, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : u64*} {{"v128.const"} {"i64x2"} {c*{c <- `c*`}:Ti64^2{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $ibytes_(64, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : f32*} {{"v128.const"} {"f32x4"} {c*{c <- `c*`}:Tf32^4{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $fbytes_(32, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`c*` : f64*} {{"v128.const"} {"f64x2"} {c*{c <- `c*`}:Tf64^2{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $fbytes_(64, c)*{c <- `c*`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`i*` : laneidx*} {{"i8x16.shuffle"} {i*{i <- `i*`}:Tlaneidx^16{}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), i*{i <- `i*`}) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.swizzle" => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.relaxed_swizzle" => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.splat" => VSPLAT_instr(`%X%`_shape(I8_lanetype, `%`_dim(16))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.splat" => VSPLAT_instr(`%X%`_shape(I16_lanetype, `%`_dim(8))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.splat" => VSPLAT_instr(`%X%`_shape(I32_lanetype, `%`_dim(4))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.splat" => VSPLAT_instr(`%X%`_shape(I64_lanetype, `%`_dim(2))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.splat" => VSPLAT_instr(`%X%`_shape(F32_lanetype, `%`_dim(4))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.splat" => VSPLAT_instr(`%X%`_shape(F64_lanetype, `%`_dim(2))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), i) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.any_true" => VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.all_true" => VTESTOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.all_true" => VTESTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.all_true" => VTESTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.all_true" => VTESTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.eq" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ne" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.lt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.lt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.gt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.gt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.le_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.le_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ge_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ge_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.eq" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ne" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.lt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.lt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.gt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.gt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.le_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.le_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ge_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ge_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.eq" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ne" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.lt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.lt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.gt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.gt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.le_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.le_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ge_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ge_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.eq" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.ne" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.lt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.gt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.le_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.ge_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.eq" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ne" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.lt" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.gt" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.le" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ge" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.eq" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ne" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.lt" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.gt" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.le" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ge" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.not" => VVUNOP_instr(V128_vectype, NOT_vvunop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.abs" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.neg" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.popcnt" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.abs" => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.neg" => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.abs" => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.neg" => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.abs" => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.neg" => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.abs" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.neg" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.sqrt" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ceil" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.floor" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.trunc" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.nearest" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.abs" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.neg" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.sqrt" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ceil" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.floor" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.trunc" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.nearest" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.and" => VVBINOP_instr(V128_vectype, AND_vvbinop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.andnot" => VVBINOP_instr(V128_vectype, ANDNOT_vvbinop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.or" => VVBINOP_instr(V128_vectype, OR_vvbinop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.xor" => VVBINOP_instr(V128_vectype, XOR_vvbinop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.min_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.min_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.max_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.max_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.avgr_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.mul" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.min_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.min_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.max_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.max_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.avgr_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.q15mulr_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_q15mulr_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.add" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.sub" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.mul" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.min_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.min_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.max_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.max_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.add" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.sub" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.mul" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.add" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.sub" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.mul" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.div" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.min" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.max" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.pmin" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.pmax" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_min" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_max" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.add" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.sub" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.mul" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.div" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.min" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.max" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.pmin" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.pmax" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_min" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_max" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "v128.bitselect" => VVTERNOP_instr(V128_vectype, BITSELECT_vvternop) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.narrow_i16x8_s" => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), S_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.narrow_i16x8_u" => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), U_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.narrow_i32x4_s" => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), S_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.narrow_i32x4_u" => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), U_sx) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_low_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_low_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_high_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_high_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_low_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_low_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_high_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_high_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_high_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_high_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.demote_f64x2_zero" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.convert_i32x4_s" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.convert_i32x4_u" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.promote_low_f32x4" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.convert_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.convert_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extadd_pairwise_i8x16_s" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extadd_pairwise_i8x16_u" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extadd_pairwise_i16x8_s" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extadd_pairwise_i16x8_u" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_low_i8x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_low_i8x16_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_high_i8x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_high_i8x16_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_dot_i8x16_i7x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_low_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_low_i16x8_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_high_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_high_i16x8_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.dot_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_low_i32x4_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_low_i32x4_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_high_i32x4_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_high_i32x4_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_dot_i8x16_i7x16_add_s" => VEXTTERNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -rec { - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:15.1-17.29 -grammar Tinstr_(I : I) : instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:16.5-16.29 - prod{in : instr} in:Tplaininstr_(I) => in - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:17.5-17.29 - prod{in : instr} in:Tblockinstr_(I) => in - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:23.1-24.52 -grammar Tinstrs_(I : I) : instr* - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:20.5-20.27 - prod{`in*` : instr*} in*{in <- `in*`}:Tinstr_(I)*{} => in*{in <- `in*`} - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:24.5-24.52 - prod{`in**` : instr**} in*{in <- `in*`}*{`in*` <- `in**`}:Tfoldedinstr_(I)*{} => $concat_(syntax instr, in*{in <- `in*`}*{`in*` <- `in**`}) - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:88.1-90.65 -grammar Tblockinstr_(I : I) : instr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:63.5-67.35 - prod{bt : blocktype, `in*` : instr*, `id?` : char?, I' : I, `id'?` : char?} {{"block"} {(?(`%`_name(lift(id?{id <- `id?`}))), I'):Tlabel_(I)} {bt:Tblocktype_(I)} {in*{in <- `in*`}:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'?{id' <- `id'?`}))):Tid?{}}} => BLOCK_instr(bt, in*{in <- `in*`}) - -- if ((id'?{id' <- `id'?`} = ?()) \/ (id'?{id' <- `id'?`} = id?{id <- `id?`})) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:68.5-72.35 - prod{bt : blocktype, `in*` : instr*, `id?` : char?, I' : I, `id'?` : char?} {{"loop"} {(?(`%`_name(lift(id?{id <- `id?`}))), I'):Tlabel_(I)} {bt:Tblocktype_(I)} {in*{in <- `in*`}:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'?{id' <- `id'?`}))):Tid?{}}} => LOOP_instr(bt, in*{in <- `in*`}) - -- if ((id'?{id' <- `id'?`} = ?()) \/ (id'?{id' <- `id'?`} = id?{id <- `id?`})) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:73.5-79.71 - prod{bt : blocktype, `in_1*` : instr*, `in_2*` : instr*, `id?` : char?, I' : I, `id_1?` : char?, `id_2?` : char?} {{"if"} {(?(`%`_name(lift(id?{id <- `id?`}))), I'):Tlabel_(I)} {bt:Tblocktype_(I)} {in_1*{in_1 <- `in_1*`}:Tinstrs_(I')} {"else"} {?(`%`_name(lift(id_1?{id_1 <- `id_1?`}))):Tid?{}} {in_2*{in_2 <- `in_2*`}:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id_2?{id_2 <- `id_2?`}))):Tid?{}}} => `IF%%ELSE%`_instr(bt, in_1*{in_1 <- `in_1*`}, in_2*{in_2 <- `in_2*`}) - -- if (((id_1?{id_1 <- `id_1?`} = ?()) \/ (id_1?{id_1 <- `id_1?`} = id?{id <- `id?`})) /\ ((id_2?{id_2 <- `id_2?`} = ?()) \/ (id_2?{id_2 <- `id_2?`} = id?{id <- `id?`}))) - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:80.5-85.35 - prod{bt : blocktype, `c*` : catch*, `in*` : instr*, `id?` : char?, I' : I, `id'?` : char?} {{"try_table"} {(?(`%`_name(lift(id?{id <- `id?`}))), I'):Tlabel_(I)} {bt:Tblocktype_(I)} {c*{c <- `c*`}:Tcatch_(I)*{}} {in*{in <- `in*`}:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'?{id' <- `id'?`}))):Tid?{}}} => TRY_TABLE_instr(bt, `%`_list(c*{c <- `c*`}), in*{in <- `in*`}) - -- if ((id'?{id' <- `id'?`} = ?()) \/ (id'?{id' <- `id'?`} = id?{id <- `id?`})) -} - -;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec -grammar Texpr_(I : I) : expr - ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{`in*` : instr*} in*{in <- `in*`}:Tinstrs_(I) => in*{in <- `in*`} - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Ttype_(I : I) : (type, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{qt : rectype, I' : I, I'' : I, n : n, `st*` : subtype*} (qt, I'):Trectype_(I) => (TYPE_type(qt), I' +++ I'') - -- if (qt = REC_rectype(`%`_list(st^n{st <- `st*`}))) - -- if (I'' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS ?(_DEF_deftype(qt, i))^(i (TAG_tag(jt), {TYPES [], TAGS [?(`%`_name(lift(id?{id <- `id?`})))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tglobal_(I : I) : (global, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{gt : globaltype, e : expr, `id?` : char?} {{"("} {"global"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {gt:Tglobaltype_(I)} {e:Texpr_(I)} {")"}} => (GLOBAL_global(gt, e), {TYPES [], TAGS [], GLOBALS [?(`%`_name(lift(id?{id <- `id?`})))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tmem_(I : I) : (mem, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{mt : memtype, `id?` : char?} {{"("} {"memory"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {mt:Tmemtype_(I)} {")"}} => (MEMORY_mem(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(`%`_name(lift(id?{id <- `id?`})))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Ttable_(I : I) : (table, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{tt : tabletype, e : expr, `id?` : char?} {{"("} {"table"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {tt:Ttabletype_(I)} {e:Texpr_(I)} {")"}} => (TABLE_table(tt, e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(`%`_name(lift(id?{id <- `id?`})))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tlocal_(I : I) : (local*, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{t : valtype, `id?` : char?} {{"("} {"local"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {t:Tvaltype_(I)} {")"}} => ([LOCAL_local(t)], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name(lift(id?{id <- `id?`})))], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tfunc_(I : I) : (func, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -- if (I' = I +++ I_1 +++ $concat_idctxt(I_2*{I_2 <- `I_2*`})) - -- Idctxt_ok: `|-%:OK`(I') - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tdatastring : byte* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`b**` : byte**} b*{b <- `b*`}*{`b*` <- `b**`}:Tstring*{} => $concat_(syntax byte, b*{b <- `b*`}*{`b*` <- `b**`}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tmemuse_(I : I) : memidx - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx} {{"("} {"memory"} {x:Tmemidx_(I)} {")"}} => x - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Toffset_(I : I) : expr - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{e : expr} {{"("} {"offset"} {e:Texpr_(I)} {")"}} => e - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tdata_(I : I) : (data, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`b*` : byte*, `id?` : char?} {{"("} {"data"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {b*{b <- `b*`}:Tdatastring} {")"}} => (DATA_data(b*{b <- `b*`}, PASSIVE_datamode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(`%`_name(lift(id?{id <- `id?`})))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`b*` : byte*, x : idx, e : expr, `id?` : char?} {{"("} {"data"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {x:Tmemuse_(I)} {e:Toffset_(I)} {b*{b <- `b*`}:Tdatastring} {")"}} => (DATA_data(b*{b <- `b*`}, ACTIVE_datamode(x, e)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(`%`_name(lift(id?{id <- `id?`})))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Telemexpr_(I : I) : expr - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{e : expr} {{"("} {"item"} {e:Texpr_(I)} {")"}} => e - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Telemlist_(I : I) : (reftype, expr*) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, `e*` : expr*} {{rt:Treftype_(I)} {e*{e <- `e*`}:Tlist(syntax expr, grammar Telemexpr_(I))}} => (rt, e*{e <- `e*`}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Ttableuse_(I : I) : tableidx - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx} {{"("} {"table"} {x:Ttableidx_(I)} {")"}} => x - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Telem_(I : I) : (elem, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, `e*` : expr*, `id?` : char?} {{"("} {"elem"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(rt, e*{e <- `e*`}):Telemlist_(I)} {")"}} => (ELEM_elem(rt, e*{e <- `e*`}, PASSIVE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id?{id <- `id?`})))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, `e*` : expr*, x : idx, e' : expr, `id?` : char?} {{"("} {"elem"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {x:Ttableuse_(I)} {e':Toffset_(I)} {(rt, e*{e <- `e*`}):Telemlist_(I)} {")"}} => (ELEM_elem(rt, e*{e <- `e*`}, ACTIVE_elemmode(x, e')), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id?{id <- `id?`})))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, `e*` : expr*, `id?` : char?} {{"("} {"elem"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {"declare"} {(rt, e*{e <- `e*`}):Telemlist_(I)} {")"}} => (ELEM_elem(rt, e*{e <- `e*`}, DECLARE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id?{id <- `id?`})))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tstart_(I : I) : (start, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx} {{"("} {"start"} {x:Tfuncidx_(I)} {")"}} => (START_start(x), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Timport_(I : I) : (import, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{nm_1 : name, nm_2 : name, xt : externtype, I' : I} {{"("} {"import"} {nm_1:Tname} {nm_2:Tname} {(xt, I'):Texterntype_(I)} {")"}} => (IMPORT_import(nm_1, nm_2, xt), I') - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texport_(I : I) : (export, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{nm : name, xx : externidx} {{"("} {"export"} {nm:Tname} {xx:Texternidx_(I)} {")"}} => (EXPORT_export(nm, xx), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportdots : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{"("} {"export"} {Tname} {")"}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Timportdots : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{"("} {"import"} {Tname} {Tname} {")"}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texporttagdots_(I : I) : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Ttagtype_(I)}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} Timportdots {Ttagtype_(I)}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportglobaldots_(I : I) : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Tglobaltype_(I)} {Texpr_(I)}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} Timportdots {Tglobaltype_(I)}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportmemdots_(I : I) : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Tmemtype_(I)}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Taddrtype?{}} {"("} {"data"} {Tdatastring} {")"}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} Timportdots {Tmemtype_(I)}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texporttabledots_(I : I) : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Ttabletype_(I)} {Texpr_(I)?{}}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Taddrtype?{}} {Treftype_(I)} {"("} {"elem"} {Telemlist_(I)} {")"}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} Timportdots {Ttabletype_(I)}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportfuncdots_(I : I) : () - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} {Ttypeuse_(I)} {Tlocal_(I)*{}} {Texpr_(I)}} => (``, ()).1 - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : ()} ``:{{Texportdots*{}} Timportdots {Ttypeuse_(I)}} => (``, ()).1 - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texporttag_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportglobal_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportmem_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texporttable_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Texportfunc_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tdatamem_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Telemtable_(I : I) : () - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tdecl_(I : I) : (decl, idctxt) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (type, idctxt)} ``:Ttype_(I) => (`` : (type, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (import, idctxt)} ``:Timport_(I) => (`` : (import, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (tag, idctxt)} ``:Ttag_(I) => (`` : (tag, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (global, idctxt)} ``:Tglobal_(I) => (`` : (global, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (mem, idctxt)} ``:Tmem_(I) => (`` : (mem, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (table, idctxt)} ``:Ttable_(I) => (`` : (table, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (func, idctxt)} ``:Tfunc_(I) => (`` : (func, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (data, idctxt)} ``:Tdata_(I) => (`` : (data, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (elem, idctxt)} ``:Telem_(I) => (`` : (elem, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (start, idctxt)} ``:Tstart_(I) => (`` : (start, idctxt) <: (decl, idctxt)) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (export, idctxt)} ``:Texport_(I) => (`` : (export, idctxt) <: (decl, idctxt)) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tmodule : module - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) - -- if (I' = $concat_idctxt(I*{I <- `I*`})) - -- Idctxt_ok: `|-%:OK`(I') - -- if (type*{type <- `type*`} = $typesd(decl*{decl <- `decl*`})) - -- if (import*{import <- `import*`} = $importsd(decl*{decl <- `decl*`})) - -- if (tag*{tag <- `tag*`} = $tagsd(decl*{decl <- `decl*`})) - -- if (global*{global <- `global*`} = $globalsd(decl*{decl <- `decl*`})) - -- if (mem*{mem <- `mem*`} = $memsd(decl*{decl <- `decl*`})) - -- if (table*{table <- `table*`} = $tablesd(decl*{decl <- `decl*`})) - -- if (func*{func <- `func*`} = $funcsd(decl*{decl <- `decl*`})) - -- if (data*{data <- `data*`} = $datasd(decl*{decl <- `decl*`})) - -- if (elem*{elem <- `elem*`} = $elemsd(decl*{decl <- `decl*`})) - -- if (lift(start?{start <- `start?`}) = $startsd(decl*{decl <- `decl*`})) - -- if (export*{export <- `export*`} = $exportsd(decl*{decl <- `decl*`})) - -- if $ordered(decl*{decl <- `decl*`}) - -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -grammar Tdecldots_(I : I) : (decl, idctxt)* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (decl, idctxt)} [``]:Tdecl_(I)*{} => [``] - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -grammar Bvar(syntax X) : () - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - prod 0x00 => ((), ()).1 - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -grammar Bsym : A - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - prod Bvar(syntax B) => $var(syntax A) - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - prod {Bvar(syntax symdots) Bvar(syntax B)} => $var(syntax A) - -;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -grammar Bsymsplit : () - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - prod{`` : ()} ``:Bvar(syntax B) => (``, ()).1 - ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - prod{`` : ()} ``:Bvar(syntax B) => (``, ()).1 - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -grammar Tvar(syntax X) : () - ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec - prod 0x00 => ((), ()).1 - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -grammar Tsym : A - ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec - prod Tvar(syntax T) => $var(syntax A) - ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec - prod {Tvar(syntax symdots) Tvar(syntax T)} => $var(syntax A) - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -grammar Tsymsplit : () - ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec - prod{`` : ()} ``:Tvar(syntax B) => (``, ()).1 - ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec - prod{`` : ()} ``:Tvar(syntax B) => (``, ()).1 - -;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -grammar Tabbrev : () - diff --git a/spectec/test-middlend/specification.exp/07-else-simplification.il b/spectec/test-middlend/specification.exp/07-else-simplification.il index 884471ee75..de8d85575b 100644 --- a/spectec/test-middlend/specification.exp/07-else-simplification.il +++ b/spectec/test-middlend/specification.exp/07-else-simplification.il @@ -314,19 +314,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -377,23 +398,27 @@ def $utf8(char*) : byte* def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] -- if ((128 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 2048)) -- if (ch!`%`_char.0 = (((2 ^ 6) * (((b_1!`%`_byte.0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] -- if (((2048 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 55296)) \/ ((57344 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 65536))) -- if (ch!`%`_char.0 = ((((2 ^ 12) * (((b_1!`%`_byte.0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] -- if ((65536 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 69632)) -- if (ch!`%`_char.0 = (((((2 ^ 18) * (((b_1!`%`_byte.0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $utf8(var_0)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -582,10 +607,18 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { @@ -593,70 +626,162 @@ rec { def $free_list(free*) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) } +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_list(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -671,6 +796,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -1035,73 +1169,157 @@ syntax Cnn = def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1410,7 +1628,15 @@ def $unpack(storagetype : storagetype) : valtype def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? @@ -1448,10 +1674,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? @@ -1489,6 +1723,19 @@ def $globalsxt(externtype*) : globaltype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsxt(var_0)) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 @@ -1502,6 +1749,19 @@ def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsxt(var_0)) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 @@ -1515,6 +1775,19 @@ def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesxt(var_0)) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 def $funcsxt(externtype*) : deftype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 @@ -1541,7 +1814,22 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($subst_typevar(typevar, var_0, var_1))) + -- wf_typeuse: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1550,11 +1838,25 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1593,7 +1895,6 @@ def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype @@ -1605,7 +1906,6 @@ def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype @@ -1618,25 +1918,20 @@ def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storaget def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype @@ -1650,6 +1945,98 @@ def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typeuse(typeuse, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_heaptype(heaptype, var_0, var_1)) + -- wf_heaptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_reftype(reftype, var_0, var_1)) + -- wf_reftype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_valtype(valtype, var_0, var_1)) + -- wf_valtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_storagetype(storagetype, var_0, var_1)) + -- wf_storagetype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_fieldtype(fieldtype, var_0, var_1)) + -- wf_fieldtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_comptype(comptype, var_0, var_1)) + -- wf_comptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_subtype(subtype, var_0, var_1)) + -- wf_subtype: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1664,97 +2051,204 @@ def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_globaltype(globaltype, var_0, var_1)) + -- wf_globaltype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_tabletype(tabletype, var_0, var_1)) + -- wf_tabletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_externtype(externtype, var_0, var_1)) + -- wf_externtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_moduletype(moduletype, var_0, var_1)) + -- wf_moduletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $free_moduletype(moduletype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = | mk_num__0(Inn : Inn, var_x : iN) @@ -2477,7 +3204,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4221,22 +4956,45 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`((consttype : consttype <: storagetype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4244,6 +5002,15 @@ def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $free_blocktype(blocktype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4255,6 +5022,15 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { @@ -4266,7 +5042,6 @@ def $shift_labelidxs(labelidx*) : labelidx* def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4276,13 +5051,10 @@ rec { def $free_instr(instr : instr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 @@ -4313,7 +5085,6 @@ def $free_instr(instr : instr) : free def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 @@ -4324,7 +5095,6 @@ def $free_instr(instr : instr) : free def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 @@ -4387,13 +5157,10 @@ def $free_instr(instr : instr) : free def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 @@ -4402,10 +5169,8 @@ def $free_instr(instr : instr) : free def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 @@ -4430,7 +5195,6 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 @@ -4441,10 +5205,8 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 @@ -4503,11 +5265,42 @@ def $free_block(instr*) : free -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) } +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = $free_instr(instr)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_block(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr(expr : expr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = $free_expr(expr)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = | ACTIVE(tableidx : tableidx, expr : expr) @@ -4698,85 +5491,216 @@ def $free_type(type : type) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free}: + `%%`(type, ret_val) + -- if (ret_val = $free_type(type)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag(tag : tag) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = $free_tag(tag)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global(global : global) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = $free_global(global)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table(table : table) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = $free_table(table)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local(local : local) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = $free_local(local)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func(func : func) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = $free_func(func)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(datamode : datamode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = $free_datamode(datamode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data(data : data) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_data_is_wf: `%%`(data : data, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_data_is_wf_0{data : data, ret_val : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = $free_data(data)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(elemmode : elemmode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = $free_elemmode(elemmode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem(elem : elem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elem_is_wf_0{elem : elem, ret_val : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = $free_elem(elem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import(import : import) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = $free_import(import)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module(module : module) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = $free_module(module)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $funcidx_module(module : module) : funcidx* ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec @@ -4862,6 +5786,21 @@ def $with_locals(context : context, localidx*, localtype*) : context? ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($with_locals(context, var_0, var_1))) + -- wf_context: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 def $clos_deftypes(deftype*) : deftype* ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 @@ -4877,6 +5816,16 @@ def $clos_valtype(context : context, valtype : valtype) : valtype def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $clos_valtype(context, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_deftype(context : context, deftype : deftype) : deftype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -4895,12 +5844,32 @@ def $clos_externtype(context : context, externtype : externtype) : externtype def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = $clos_externtype(context, externtype)) + -- wf_externtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype(context : context, moduletype : moduletype) : moduletype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $clos_moduletype(context, moduletype)) + -- wf_moduletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -4946,6 +5915,7 @@ relation Expand: `%~~%`(deftype, comptype) rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: `%~~%`(deftype, comptype) -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`($unrolldt(deftype)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -4971,6 +5941,16 @@ def $unrollht_(context : context, heaptype : heaptype) : subtype ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = $unrollht_(context, heaptype)) + -- wf_subtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5122,6 +6102,7 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrollht_(C, (typeuse : typeuse <: heaptype))))*{typeuse <- `typeuse*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} @@ -5193,6 +6174,7 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) -- wf_context: `%`(C) + -- wf_subtype: `%`($unrolldt(deftype_1)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5527,6 +6509,7 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrolldt(C.TYPES_context[x!`%`_uN.0])))*{x <- `x*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} @@ -5653,6 +6636,7 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- (if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -5825,21 +6809,26 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(?(VCONST_val(Vnn, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -5847,6 +6836,7 @@ relation Defaultable: `|-%DEFAULTABLE`(valtype) `|-%DEFAULTABLE`(t) -- if (!($default_(t)) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6013,6 +7003,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) @@ -6224,6 +7215,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6266,6 +7258,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6296,6 +7289,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6364,6 +7358,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6813,6 +7808,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if (i!`%`_uN.0 < (2 * $dim(sh!`%`_bshape.0)!`%`_dim.0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh!`%`_bshape.0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -6828,6 +7824,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) @@ -6836,6 +7833,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) @@ -6891,6 +7889,7 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -6936,6 +7935,7 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) `|-%NONDEFAULTABLE`(t) -- if (!($default_(t)) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7069,6 +8069,7 @@ relation Tag_ok: `%|-%:%`(context, tag, tagtype) `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`($clos_tagtype(C, tagtype)) -- wf_tag: `%`(TAG_tag(tagtype)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7216,6 +8217,7 @@ relation Import_ok: `%|-%:%`(context, import, externtype) `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`($clos_externtype(C, xt)) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7331,7 +8333,6 @@ relation wf_nonfuncs: `%`(nonfuncs) def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -7361,6 +8362,12 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`($clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + -- (wf_uN: `%%`(32, iter))*{iter <- $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))} + -- (wf_typeuse: `%`(iter))*{iter <- $tagsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_globaltype: `%`(iter))*{iter <- $globalsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_memtype: `%`(iter))*{iter <- $memsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_tabletype: `%`(iter))*{iter <- $tablesxt(xt_I*{xt_I <- `xt_I*`})} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7404,81 +8411,272 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $signed_(N : N, nat : nat) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7510,10 +8708,16 @@ def $sx(storagetype : storagetype) : sx?? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7542,7 +8746,6 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN @@ -7562,28 +8765,23 @@ def $ipopcnt_(N : N, iN : iN) : iN def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN((i!`%`_uN.0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN((i!`%`_uN.0 \ (2 ^ M)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7591,7 +8789,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7599,7 +8796,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? -- if ((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7607,13 +8803,11 @@ def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) -- if ((j_1 = $signed_(N, i_1!`%`_uN.0)) /\ (j_2 = $signed_(N, i_2!`%`_uN.0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7641,19 +8835,15 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7704,140 +8894,323 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* +def $fsqrt_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* +def $fceil_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* +def $ffloor_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* +def $ftrunc_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* +def $fnearest_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* +def $fadd_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +def $fsub_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +def $fmul_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 +def $fdiv_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 +def $fmin_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fge_(N : N, fN : fN, fN : fN) : u32 +def $fmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmin_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fcopysign_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $feq_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fne_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $flt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fgt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fle_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -7856,26 +9229,69 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7883,7 +9299,16 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -7891,7 +9316,15 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7899,103 +9332,103 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $unop_(numtype, unop_, num_)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = $binop_(numtype, binop_, num_, num__0)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -8033,37 +9466,48 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $cvtop__(numtype_1, numtype_2, cvtop__, num_)) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ @@ -8108,13 +9552,11 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else (if ($signed_(N, i!`%`_uN.0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[(i!`%`_uN.0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* @@ -8123,7 +9565,6 @@ def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* @@ -8142,7 +9583,6 @@ def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8152,7 +9592,6 @@ def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, s -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8204,7 +9643,6 @@ def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8215,7 +9653,6 @@ def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8226,8 +9663,6 @@ def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} @@ -8238,7 +9673,6 @@ def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : v -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ @@ -8247,7 +9681,6 @@ def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : i -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 @@ -8255,7 +9688,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)))*{c_1 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -8268,7 +9700,6 @@ def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ @@ -8304,175 +9735,136 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = $lcvtop__(shape_1, shape_2, vcvtop__, lane_)) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ @@ -8482,7 +9874,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8491,7 +9882,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8500,7 +9890,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) @@ -8508,31 +9897,25 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8553,8 +9936,6 @@ def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = i!`%`_uN.0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ @@ -8563,32 +9944,24 @@ def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8599,8 +9972,6 @@ def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : i -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8612,22 +9983,10 @@ def $ivmul_(N : N, iN*, iN*) : iN* def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ @@ -8638,7 +9997,6 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -8998,20 +10356,38 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval? def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = ?((val : val <: fieldval)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = ?(val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -9082,11 +10458,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9097,61 +10491,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9162,123 +10664,337 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[x!`%`_uN.0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? @@ -9289,12 +11005,21 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? -- if (i'!`%`_uN.0 = (|r'*{r' <- `r'*`}| + n)) -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} -- if ((i'!`%`_uN.0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !($growtable(tableinst, nat, ref))) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem(meminst : meminst, nat : nat) : meminst? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9304,12 +11029,20 @@ def $growmem(meminst : meminst, nat : nat) : meminst? -- if ((i'!`%`_uN.0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} -- if (i'!`%`_uN.0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !($growmem(meminst, nat))) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -9515,26 +11248,76 @@ def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $inst_valtype(moduleinst, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = $inst_reftype(moduleinst, reftype)) + -- wf_reftype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = $inst_globaltype(moduleinst, globaltype)) + -- wf_globaltype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $inst_memtype(moduleinst, memtype)) + -- wf_memtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = $inst_tabletype(moduleinst, tabletype)) + -- wf_tabletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -9886,6 +11669,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) -- if (c <- $unop_(nt, unop, c_1)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -9894,6 +11678,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) -- if ($unop_(nt, unop, c_1) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) @@ -9902,6 +11687,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9911,6 +11697,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) -- if ($binop_(nt, binop, c_1, c_2) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9920,6 +11707,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9928,6 +11716,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) @@ -9937,6 +11726,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) @@ -9945,6 +11735,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) @@ -9953,6 +11744,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -9961,6 +11753,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -9970,6 +11763,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -9980,6 +11774,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9988,6 +11783,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vunop_(sh, vunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -9996,6 +11792,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) -- if ($vunop_(sh, vunop, c_1) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) @@ -10004,6 +11801,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -10013,6 +11811,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -10022,6 +11821,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10032,6 +11832,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10044,6 +11845,8 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) -- if (!($proj_num__0(c))!`%`_uN.0 = $prod($inez_($jsizenn(Jnn), !($proj_lane__2(i)))!`%`_uN.0*{i <- `i*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10053,6 +11856,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- wf_uN: `%%`(128, $vrelop_(sh, vrelop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) @@ -10062,6 +11866,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- wf_uN: `%%`(128, $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) @@ -10071,6 +11876,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, $vbitmaskop_(sh, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10079,6 +11885,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- wf_uN: `%%`(128, $vswizzlop_(sh, swizzlop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) @@ -10088,6 +11895,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- wf_uN: `%%`(128, $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) @@ -10097,6 +11905,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10106,6 +11916,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -10116,6 +11927,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -10125,6 +11938,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -10135,6 +11951,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- wf_uN: `%%`(128, $vextunop__(sh_1, sh_2, vextunop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10143,6 +11960,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- wf_uN: `%%`(128, $vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) @@ -10152,6 +11970,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- wf_uN: `%%`(128, $vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10162,6 +11981,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) + -- wf_uN: `%%`(128, $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) @@ -10171,6 +11991,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- wf_uN: `%%`(128, $vcvtop__(sh_1, sh_2, vcvtop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10180,11 +12001,19 @@ def $blocktype_(state : state, blocktype : blocktype) : instrtype ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $blocktype_(state, blocktype)) + -- wf_instrtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) @@ -10192,6 +12021,7 @@ relation `Step_read_before_br_on_cast-fail`: `%`(config) rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -10201,6 +12031,7 @@ relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10224,6 +12055,7 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10234,6 +12066,7 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10243,6 +12076,7 @@ relation `Step_read_before_table.fill-zero`: `%`(config) rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10252,6 +12086,8 @@ relation `Step_read_before_table.copy-zero`: `%`(config) rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10268,6 +12104,8 @@ relation `Step_read_before_table.copy-le`: `%`(config) rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10299,6 +12137,8 @@ relation `Step_read_before_table.copy-gt`: `%`(config) rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10308,6 +12148,8 @@ relation `Step_read_before_table.init-zero`: `%`(config) rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10317,6 +12159,7 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10326,6 +12169,8 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10342,6 +12187,8 @@ relation `Step_read_before_memory.copy-le`: `%`(config) rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10351,6 +12198,8 @@ relation `Step_read_before_memory.init-zero`: `%`(config) rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10360,6 +12209,7 @@ relation `Step_read_before_ref.test-false`: `%`(config) rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -10369,6 +12219,7 @@ relation `Step_read_before_ref.cast-fail`: `%`(config) rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10377,6 +12228,24 @@ relation `Step_read_before_array.fill-zero`: `%`(config) rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10386,6 +12255,7 @@ relation `Step_read_before_array.copy-zero`: `%`(config) rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10393,6 +12263,7 @@ relation `Step_read_before_array.copy-zero`: `%`(config) rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10409,6 +12280,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10416,6 +12288,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10451,6 +12324,7 @@ relation `Step_read_before_array.copy-gt`: `%`(config) rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10458,6 +12332,7 @@ relation `Step_read_before_array.copy-gt`: `%`(config) rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10467,6 +12342,7 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10474,6 +12350,32 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10484,6 +12386,7 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10492,6 +12395,7 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10509,6 +12413,7 @@ relation `Step_read_before_array.init_data-num`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10517,6 +12422,7 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10526,6 +12432,7 @@ relation Step_read: `%~>%`(config, instr*) rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10534,6 +12441,7 @@ relation Step_read: `%~>%`(config, instr*) rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10542,6 +12450,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -10555,6 +12464,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10568,6 +12478,7 @@ relation Step_read: `%~>%`(config, instr*) rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10585,6 +12496,7 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) @@ -10595,6 +12507,7 @@ relation Step_read: `%~>%`(config, instr*) rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10621,6 +12534,7 @@ relation Step_read: `%~>%`(config, instr*) rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) @@ -10667,6 +12581,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10676,6 +12591,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10704,6 +12620,7 @@ relation Step_read: `%~>%`(config, instr*) rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10713,6 +12630,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10720,12 +12638,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10733,6 +12653,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[!($proj_num__0(i))!`%`_uN.0] : ref <: instr)]) -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10740,6 +12661,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -10748,6 +12670,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10774,6 +12697,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10817,6 +12742,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10832,6 +12759,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) -- if (n =/= 0) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) <= |$table(z, x).REFS_tableinst|) /\ ((!($proj_num__0(j))!`%`_uN.0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -10844,6 +12772,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10851,6 +12780,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -10858,6 +12789,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10865,6 +12797,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) @@ -10872,6 +12806,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10879,6 +12814,8 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10886,6 +12823,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10894,6 +12832,9 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) rule `vload-splat-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10913,6 +12855,9 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -10922,6 +12867,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10931,6 +12877,9 @@ relation Step_read: `%~>%`(config, instr*) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10938,6 +12887,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) @@ -10948,6 +12898,10 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -10958,6 +12912,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -10966,6 +12921,7 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10992,6 +12948,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -11038,6 +12996,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11078,6 +13038,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -11092,6 +13053,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -11107,6 +13069,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11121,6 +13085,8 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0])) : val <: instr)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0]))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11130,6 +13096,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (!($default_($unpack(zt))) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11138,6 +13106,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11146,6 +13115,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[!($proj_num__0(i))!`%`_uN.0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -11154,6 +13124,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(i))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11164,6 +13135,11 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[!($proj_num__0(i))!`%`_uN.0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11178,6 +13154,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) @@ -11185,6 +13162,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0])) : val <: instr)]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0]))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11210,21 +13189,21 @@ relation Step_read: `%~>%`(config, instr*) rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if (n =/= 0) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11249,6 +13228,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -11256,23 +13236,21 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if (n =/= 0) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- if ((!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) @@ -11317,6 +13295,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11324,25 +13303,24 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if (n =/= 0) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11362,6 +13340,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11370,6 +13349,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11388,6 +13368,10 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11460,6 +13444,8 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) -- if (exn = {TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) @@ -11481,6 +13467,7 @@ relation Step: `%~>%`(config, config) rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11488,6 +13475,7 @@ relation Step: `%~>%`(config, config) rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) @@ -11495,6 +13483,8 @@ relation Step: `%~>%`(config, config) rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) -- if (ti = !($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`(!($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) @@ -11514,6 +13504,7 @@ relation Step: `%~>%`(config, config) rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11521,6 +13512,7 @@ relation Step: `%~>%`(config, config) rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11528,6 +13520,7 @@ relation Step: `%~>%`(config, config) rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11535,6 +13528,8 @@ relation Step: `%~>%`(config, config) rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11542,6 +13537,7 @@ relation Step: `%~>%`(config, config) rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11549,6 +13545,7 @@ relation Step: `%~>%`(config, config) rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11556,6 +13553,7 @@ relation Step: `%~>%`(config, config) rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11565,6 +13563,7 @@ relation Step: `%~>%`(config, config) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0)) @@ -11573,6 +13572,8 @@ relation Step: `%~>%`(config, config) rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) -- if (mi = !($growmem($mem(z, x), n))) + -- wf_meminst: `%`(!($growmem($mem(z, x), n))) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) @@ -11594,6 +13595,7 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11618,6 +13620,7 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11633,6 +13636,7 @@ relation Step: `%~>%`(config, config) rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11695,9 +13699,18 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = $alloctag(store, tagtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11711,14 +13724,38 @@ def $alloctags(store : store, tagtype*) : (store, tagaddr*) -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $alloctags(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = $allocglobal(store, globaltype, val)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11732,14 +13769,38 @@ def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $allocglobals(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $allocmem(store, memtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11753,14 +13814,38 @@ def $allocmems(store : store, memtype*) : (store, memaddr*) -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocmems(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = $alloctable(store, tabletype, ref)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11774,14 +13859,39 @@ def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $alloctables(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = $allocfunc(store, deftype, funccode, moduleinst)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11795,14 +13905,38 @@ def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funca -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = $allocfuncs(store, var_0, var_1, var_2)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocdata(store, datatype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11816,14 +13950,38 @@ def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocdatas(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocelem(store, elemtype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11837,29 +13995,59 @@ def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocelems(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -11888,8 +14076,6 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[x!`%`_uN.0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -11901,16 +14087,36 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = $allocmodule(store, module, var_0, var_1, var_2, var_3)) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_(dataidx : dataidx, data : data) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = $rundata_(dataidx, data)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_(elemidx : elemidx, elem : elem) : instr* @@ -11918,13 +14124,18 @@ def $runelem_(elemidx : elemidx, elem : elem) : instr* def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = $runelem_(elemidx, elem)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11937,13 +14148,27 @@ def $evalexprs(state : state, expr*) : (state, ref*) def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) -- wf_state: `%`(z') } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprs(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 @@ -11957,6 +14182,21 @@ def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprss(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 def $evalglobals(state : state, globaltype*, expr*) : (state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 @@ -11967,12 +14207,27 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- let{s : store, f : frame} `%;%`_state(s, f) = z' -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $evalglobals(state, var_0, var_1)) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate(store : store, module : module, externaddr*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -11996,7 +14251,6 @@ def $instantiate(store : store, module : module, externaddr*) : config -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -12011,15 +14265,34 @@ def $instantiate(store : store, module : module, externaddr*) : config -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = $instantiate(store, module, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke(store : store, funcaddr : funcaddr, val*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $invoke(store, funcaddr, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -12038,6 +14311,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -12082,11 +14363,23 @@ rec { def $concat_idctxt(idctxt*) : idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) } +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $concat_idctxt(var_0)) + -- wf_idctxt: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec relation Idctxt_ok: `|-%:OK`(idctxt) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -12105,6 +14398,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12219,6 +14523,19 @@ def $importsd(decl*) : import* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $importsd(var_0)) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 @@ -12232,6 +14549,19 @@ def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tagsd(var_0)) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 @@ -12245,6 +14575,19 @@ def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsd(var_0)) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 @@ -12258,6 +14601,19 @@ def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsd(var_0)) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 @@ -12271,6 +14627,19 @@ def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesd(var_0)) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 @@ -12284,6 +14653,19 @@ def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $funcsd(var_0)) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 @@ -12297,6 +14679,19 @@ def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $datasd(var_0)) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 @@ -12310,6 +14705,19 @@ def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $elemsd(var_0)) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 @@ -12323,6 +14731,19 @@ def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $startsd(var_0)) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 def $exportsd(decl*) : export* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 @@ -12333,6 +14754,19 @@ def $exportsd(decl*) : export* def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) } +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $exportsd(var_0)) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} +} + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $ordered(decl*) : bool ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12538,6 +14972,7 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -13008,6 +15443,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -13033,6 +15476,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -13046,6 +15498,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -15410,7 +17875,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -15481,7 +17946,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -15490,7 +17955,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec diff --git a/spectec/test-middlend/specification.exp/08-uncase-removal.il b/spectec/test-middlend/specification.exp/08-uncase-removal.il index e559d0aee7..e382c789eb 100644 --- a/spectec/test-middlend/specification.exp/08-uncase-removal.il +++ b/spectec/test-middlend/specification.exp/08-uncase-removal.il @@ -329,19 +329,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -402,23 +423,27 @@ def $utf8(char*) : byte* def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $utf8(var_0)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,10 +637,18 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { @@ -623,70 +656,162 @@ rec { def $free_list(free*) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) } +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_list(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -701,6 +826,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -1065,73 +1199,157 @@ syntax Cnn = def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1440,7 +1658,15 @@ def $unpack(storagetype : storagetype) : valtype def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? @@ -1478,10 +1704,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? @@ -1519,6 +1753,19 @@ def $globalsxt(externtype*) : globaltype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsxt(var_0)) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 @@ -1532,6 +1779,19 @@ def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsxt(var_0)) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 @@ -1545,6 +1805,19 @@ def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesxt(var_0)) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 def $funcsxt(externtype*) : deftype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 @@ -1571,7 +1844,22 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($subst_typevar(typevar, var_0, var_1))) + -- wf_typeuse: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1580,11 +1868,25 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1623,7 +1925,6 @@ def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype @@ -1635,7 +1936,6 @@ def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype @@ -1648,25 +1948,20 @@ def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storaget def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype @@ -1680,6 +1975,98 @@ def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typeuse(typeuse, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_heaptype(heaptype, var_0, var_1)) + -- wf_heaptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_reftype(reftype, var_0, var_1)) + -- wf_reftype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_valtype(valtype, var_0, var_1)) + -- wf_valtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_storagetype(storagetype, var_0, var_1)) + -- wf_storagetype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_fieldtype(fieldtype, var_0, var_1)) + -- wf_fieldtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_comptype(comptype, var_0, var_1)) + -- wf_comptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_subtype(subtype, var_0, var_1)) + -- wf_subtype: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1694,97 +2081,204 @@ def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_globaltype(globaltype, var_0, var_1)) + -- wf_globaltype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_tabletype(tabletype, var_0, var_1)) + -- wf_tabletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_externtype(externtype, var_0, var_1)) + -- wf_externtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_moduletype(moduletype, var_0, var_1)) + -- wf_moduletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $free_moduletype(moduletype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = | mk_num__0(Inn : Inn, var_x : iN) @@ -2517,7 +3244,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4271,22 +5006,45 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`((consttype : consttype <: storagetype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4294,6 +5052,15 @@ def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $free_blocktype(blocktype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4305,6 +5072,15 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { @@ -4316,7 +5092,6 @@ def $shift_labelidxs(labelidx*) : labelidx* def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4326,13 +5101,10 @@ rec { def $free_instr(instr : instr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 @@ -4363,7 +5135,6 @@ def $free_instr(instr : instr) : free def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 @@ -4374,7 +5145,6 @@ def $free_instr(instr : instr) : free def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 @@ -4437,13 +5207,10 @@ def $free_instr(instr : instr) : free def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 @@ -4452,10 +5219,8 @@ def $free_instr(instr : instr) : free def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 @@ -4480,7 +5245,6 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 @@ -4491,10 +5255,8 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 @@ -4553,11 +5315,42 @@ def $free_block(instr*) : free -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) } +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = $free_instr(instr)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_block(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr(expr : expr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = $free_expr(expr)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = | ACTIVE(tableidx : tableidx, expr : expr) @@ -4748,85 +5541,216 @@ def $free_type(type : type) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free}: + `%%`(type, ret_val) + -- if (ret_val = $free_type(type)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag(tag : tag) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = $free_tag(tag)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global(global : global) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = $free_global(global)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table(table : table) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = $free_table(table)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local(local : local) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = $free_local(local)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func(func : func) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = $free_func(func)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(datamode : datamode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = $free_datamode(datamode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data(data : data) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_data_is_wf: `%%`(data : data, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_data_is_wf_0{data : data, ret_val : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = $free_data(data)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(elemmode : elemmode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = $free_elemmode(elemmode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem(elem : elem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elem_is_wf_0{elem : elem, ret_val : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = $free_elem(elem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import(import : import) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = $free_import(import)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module(module : module) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = $free_module(module)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $funcidx_module(module : module) : funcidx* ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec @@ -4912,6 +5836,21 @@ def $with_locals(context : context, localidx*, localtype*) : context? ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($with_locals(context, var_0, var_1))) + -- wf_context: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 def $clos_deftypes(deftype*) : deftype* ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 @@ -4927,6 +5866,16 @@ def $clos_valtype(context : context, valtype : valtype) : valtype def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $clos_valtype(context, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_deftype(context : context, deftype : deftype) : deftype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -4945,12 +5894,32 @@ def $clos_externtype(context : context, externtype : externtype) : externtype def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = $clos_externtype(context, externtype)) + -- wf_externtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype(context : context, moduletype : moduletype) : moduletype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $clos_moduletype(context, moduletype)) + -- wf_moduletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -4996,6 +5965,7 @@ relation Expand: `%~~%`(deftype, comptype) rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: `%~~%`(deftype, comptype) -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`($unrolldt(deftype)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -5021,6 +5991,16 @@ def $unrollht_(context : context, heaptype : heaptype) : subtype ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = $unrollht_(context, heaptype)) + -- wf_subtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5172,6 +6152,7 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrollht_(C, (typeuse : typeuse <: heaptype))))*{typeuse <- `typeuse*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} @@ -5243,6 +6224,7 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) -- wf_context: `%`(C) + -- wf_subtype: `%`($unrolldt(deftype_1)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5577,6 +6559,7 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrolldt(C.TYPES_context[$proj_uN_0(x).0])))*{x <- `x*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} @@ -5703,6 +6686,7 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -5875,21 +6859,26 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(?(VCONST_val(Vnn, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -5897,6 +6886,7 @@ relation Defaultable: `|-%DEFAULTABLE`(valtype) `|-%DEFAULTABLE`(t) -- if (!($default_(t)) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6063,6 +7053,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) @@ -6274,6 +7265,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6316,6 +7308,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6346,6 +7339,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6414,6 +7408,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6863,6 +7858,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -6878,6 +7874,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) @@ -6886,6 +7883,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) @@ -6941,6 +7939,7 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -6986,6 +7985,7 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) `|-%NONDEFAULTABLE`(t) -- if (!($default_(t)) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7119,6 +8119,7 @@ relation Tag_ok: `%|-%:%`(context, tag, tagtype) `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`($clos_tagtype(C, tagtype)) -- wf_tag: `%`(TAG_tag(tagtype)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7266,6 +8267,7 @@ relation Import_ok: `%|-%:%`(context, import, externtype) `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`($clos_externtype(C, xt)) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7381,7 +8383,6 @@ relation wf_nonfuncs: `%`(nonfuncs) def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -7411,6 +8412,12 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`($clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + -- (wf_uN: `%%`(32, iter))*{iter <- $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))} + -- (wf_typeuse: `%`(iter))*{iter <- $tagsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_globaltype: `%`(iter))*{iter <- $globalsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_memtype: `%`(iter))*{iter <- $memsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_tabletype: `%`(iter))*{iter <- $tablesxt(xt_I*{xt_I <- `xt_I*`})} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7464,81 +8471,272 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $signed_(N : N, nat : nat) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7570,10 +8768,16 @@ def $sx(storagetype : storagetype) : sx?? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7602,7 +8806,6 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN @@ -7622,28 +8825,23 @@ def $ipopcnt_(N : N, iN : iN) : iN def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ M)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7651,7 +8849,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7659,7 +8856,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? -- if ((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7667,13 +8863,11 @@ def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) -- if ((j_1 = $signed_(N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7701,19 +8895,15 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7764,140 +8954,323 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* +def $fsqrt_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* +def $fceil_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* +def $ffloor_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* +def $ftrunc_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* +def $fnearest_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* +def $fadd_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +def $fsub_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +def $fmul_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 +def $fdiv_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 +def $fmin_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fge_(N : N, fN : fN, fN : fN) : u32 +def $fmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmin_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fcopysign_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $feq_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fne_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $flt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fgt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fle_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -7916,26 +9289,69 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7943,7 +9359,16 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -7951,7 +9376,15 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -7959,103 +9392,103 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $unop_(numtype, unop_, num_)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = $binop_(numtype, binop_, num_, num__0)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -8093,37 +9526,48 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $cvtop__(numtype_1, numtype_2, cvtop__, num_)) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ @@ -8168,13 +9612,11 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if ($signed_(N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* @@ -8183,7 +9625,6 @@ def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* @@ -8202,7 +9643,6 @@ def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8212,7 +9652,6 @@ def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, s -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* @@ -8264,7 +9703,6 @@ def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8275,7 +9713,6 @@ def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8286,8 +9723,6 @@ def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_ -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c).0)))))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} @@ -8298,7 +9733,6 @@ def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : v -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ @@ -8307,7 +9741,6 @@ def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : i -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 @@ -8315,7 +9748,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))).0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))).0)))*{c_1 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -8328,7 +9760,6 @@ def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ @@ -8364,175 +9795,136 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = $lcvtop__(shape_1, shape_2, vcvtop__, lane_)) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ @@ -8542,7 +9934,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8551,7 +9942,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8560,7 +9950,6 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) @@ -8568,31 +9957,25 @@ def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_ def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8613,8 +9996,6 @@ def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $proj_uN_0(i).0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ @@ -8623,32 +10004,24 @@ def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ @@ -8659,8 +10032,6 @@ def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : i -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -8672,22 +10043,10 @@ def $ivmul_(N : N, iN*, iN*) : iN* def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ @@ -8698,7 +10057,6 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -9058,20 +10416,38 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval? def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = ?((val : val <: fieldval)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = ?(val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -9142,11 +10518,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9157,61 +10551,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9222,123 +10724,337 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? @@ -9349,12 +11065,21 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? -- if ($proj_uN_0(i').0 = (|r'*{r' <- `r'*`}| + n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j).0))?{j <- `j?`} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !($growtable(tableinst, nat, ref))) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem(meminst : meminst, nat : nat) : meminst? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9364,12 +11089,20 @@ def $growmem(meminst : meminst, nat : nat) : meminst? -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j).0))?{j <- `j?`} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !($growmem(meminst, nat))) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -9575,26 +11308,76 @@ def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $inst_valtype(moduleinst, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = $inst_reftype(moduleinst, reftype)) + -- wf_reftype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = $inst_globaltype(moduleinst, globaltype)) + -- wf_globaltype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $inst_memtype(moduleinst, memtype)) + -- wf_memtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = $inst_tabletype(moduleinst, tabletype)) + -- wf_tabletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -9946,6 +11729,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) -- if (c <- $unop_(nt, unop, c_1)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -9954,6 +11738,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) -- if ($unop_(nt, unop, c_1) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) @@ -9962,6 +11747,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9971,6 +11757,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) -- if ($binop_(nt, binop, c_1, c_2) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -9980,6 +11767,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9988,6 +11776,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) @@ -9997,6 +11786,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) @@ -10005,6 +11795,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) @@ -10013,6 +11804,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10021,6 +11813,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -10030,6 +11823,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10040,6 +11834,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10048,6 +11843,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vunop_(sh, vunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10056,6 +11852,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) -- if ($vunop_(sh, vunop, c_1) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) @@ -10064,6 +11861,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -10073,6 +11871,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -10082,6 +11881,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10092,6 +11892,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10104,6 +11905,8 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10113,6 +11916,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- wf_uN: `%%`(128, $vrelop_(sh, vrelop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) @@ -10122,6 +11926,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- wf_uN: `%%`(128, $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) @@ -10131,6 +11936,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, $vbitmaskop_(sh, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10139,6 +11945,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- wf_uN: `%%`(128, $vswizzlop_(sh, swizzlop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) @@ -10148,6 +11955,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- wf_uN: `%%`(128, $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) @@ -10157,6 +11965,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10166,6 +11976,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -10176,6 +11987,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -10185,6 +11998,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -10195,6 +12011,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- wf_uN: `%%`(128, $vextunop__(sh_1, sh_2, vextunop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10203,6 +12020,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- wf_uN: `%%`(128, $vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) @@ -10212,6 +12030,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- wf_uN: `%%`(128, $vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10222,6 +12041,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- wf_uN: `%%`(128, $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) @@ -10231,6 +12051,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- wf_uN: `%%`(128, $vcvtop__(sh_1, sh_2, vcvtop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10240,11 +12061,19 @@ def $blocktype_(state : state, blocktype : blocktype) : instrtype ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $blocktype_(state, blocktype)) + -- wf_instrtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) @@ -10252,6 +12081,7 @@ relation `Step_read_before_br_on_cast-fail`: `%`(config) rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -10261,6 +12091,7 @@ relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10284,6 +12115,7 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10294,6 +12126,7 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10303,6 +12136,7 @@ relation `Step_read_before_table.fill-zero`: `%`(config) rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10312,6 +12146,8 @@ relation `Step_read_before_table.copy-zero`: `%`(config) rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10328,6 +12164,8 @@ relation `Step_read_before_table.copy-le`: `%`(config) rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10359,6 +12197,8 @@ relation `Step_read_before_table.copy-gt`: `%`(config) rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10368,6 +12208,8 @@ relation `Step_read_before_table.init-zero`: `%`(config) rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10377,6 +12219,7 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10386,6 +12229,8 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10402,6 +12247,8 @@ relation `Step_read_before_memory.copy-le`: `%`(config) rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10411,6 +12258,8 @@ relation `Step_read_before_memory.init-zero`: `%`(config) rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10420,6 +12269,7 @@ relation `Step_read_before_ref.test-false`: `%`(config) rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -10429,6 +12279,7 @@ relation `Step_read_before_ref.cast-fail`: `%`(config) rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10437,6 +12288,24 @@ relation `Step_read_before_array.fill-zero`: `%`(config) rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10446,6 +12315,7 @@ relation `Step_read_before_array.copy-zero`: `%`(config) rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10453,6 +12323,7 @@ relation `Step_read_before_array.copy-zero`: `%`(config) rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10469,6 +12340,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10476,6 +12348,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10511,6 +12384,7 @@ relation `Step_read_before_array.copy-gt`: `%`(config) rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10518,6 +12392,7 @@ relation `Step_read_before_array.copy-gt`: `%`(config) rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10527,6 +12402,7 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10534,6 +12410,32 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10544,6 +12446,7 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10552,6 +12455,7 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10569,6 +12473,7 @@ relation `Step_read_before_array.init_data-num`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10577,6 +12482,7 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10586,6 +12492,7 @@ relation Step_read: `%~>%`(config, instr*) rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10594,6 +12501,7 @@ relation Step_read: `%~>%`(config, instr*) rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10602,6 +12510,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -10615,6 +12524,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10628,6 +12538,7 @@ relation Step_read: `%~>%`(config, instr*) rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10645,6 +12556,7 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) @@ -10655,6 +12567,7 @@ relation Step_read: `%~>%`(config, instr*) rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -10681,6 +12594,7 @@ relation Step_read: `%~>%`(config, instr*) rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) @@ -10727,6 +12641,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10736,6 +12651,7 @@ relation Step_read: `%~>%`(config, instr*) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10764,6 +12680,7 @@ relation Step_read: `%~>%`(config, instr*) rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) @@ -10773,6 +12690,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10780,12 +12698,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10793,6 +12713,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0] : ref <: instr)]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10800,6 +12721,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -10808,6 +12730,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -10834,6 +12757,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10877,6 +12802,8 @@ relation Step_read: `%~>%`(config, instr*) rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10892,6 +12819,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -10904,6 +12832,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10911,6 +12840,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -10918,6 +12849,7 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10925,6 +12857,8 @@ relation Step_read: `%~>%`(config, instr*) rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) @@ -10932,6 +12866,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10939,6 +12874,8 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10946,6 +12883,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10954,6 +12892,9 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[(($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) rule `vload-splat-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10973,6 +12915,9 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -10982,6 +12927,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) @@ -10991,6 +12937,9 @@ relation Step_read: `%~>%`(config, instr*) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10998,6 +12947,7 @@ relation Step_read: `%~>%`(config, instr*) rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) @@ -11008,6 +12958,10 @@ relation Step_read: `%~>%`(config, instr*) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -11018,6 +12972,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -11026,6 +12981,7 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -11052,6 +13008,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -11098,6 +13056,8 @@ relation Step_read: `%~>%`(config, instr*) rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11138,6 +13098,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -11152,6 +13113,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -11167,6 +13129,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11181,6 +13145,8 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])) : val <: instr)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11190,6 +13156,8 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (!($default_($unpack(zt))) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11198,6 +13166,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11206,6 +13175,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -11214,6 +13184,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11224,6 +13195,11 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11238,6 +13214,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) @@ -11245,6 +13222,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])) : val <: instr)]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11270,21 +13249,21 @@ relation Step_read: `%~>%`(config, instr*) rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11309,6 +13288,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -11316,23 +13296,21 @@ relation Step_read: `%~>%`(config, instr*) rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) @@ -11377,6 +13355,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11384,25 +13363,24 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11422,6 +13400,7 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11430,6 +13409,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11448,6 +13428,10 @@ relation Step_read: `%~>%`(config, instr*) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -11520,6 +13504,8 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) @@ -11541,6 +13527,7 @@ relation Step: `%~>%`(config, config) rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11548,6 +13535,7 @@ relation Step: `%~>%`(config, config) rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) @@ -11555,6 +13543,8 @@ relation Step: `%~>%`(config, config) rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) -- if (ti = !($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`(!($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) @@ -11574,6 +13564,7 @@ relation Step: `%~>%`(config, config) rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11581,6 +13572,7 @@ relation Step: `%~>%`(config, config) rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11588,6 +13580,7 @@ relation Step: `%~>%`(config, config) rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11595,6 +13588,8 @@ relation Step: `%~>%`(config, config) rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11602,6 +13597,7 @@ relation Step: `%~>%`(config, config) rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11609,6 +13605,7 @@ relation Step: `%~>%`(config, config) rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) @@ -11616,6 +13613,7 @@ relation Step: `%~>%`(config, config) rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11625,6 +13623,7 @@ relation Step: `%~>%`(config, config) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) @@ -11633,6 +13632,8 @@ relation Step: `%~>%`(config, config) rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) -- if (mi = !($growmem($mem(z, x), n))) + -- wf_meminst: `%`(!($growmem($mem(z, x), n))) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) @@ -11654,6 +13655,7 @@ relation Step: `%~>%`(config, config) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11678,6 +13680,7 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11693,6 +13696,7 @@ relation Step: `%~>%`(config, config) rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) @@ -11755,9 +13759,18 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = $alloctag(store, tagtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11771,14 +13784,38 @@ def $alloctags(store : store, tagtype*) : (store, tagaddr*) -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $alloctags(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = $allocglobal(store, globaltype, val)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11792,14 +13829,38 @@ def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $allocglobals(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $allocmem(store, memtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11813,14 +13874,38 @@ def $allocmems(store : store, memtype*) : (store, memaddr*) -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocmems(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = $alloctable(store, tabletype, ref)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11834,14 +13919,39 @@ def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $alloctables(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = $allocfunc(store, deftype, funccode, moduleinst)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11855,14 +13965,38 @@ def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funca -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = $allocfuncs(store, var_0, var_1, var_2)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocdata(store, datatype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11876,14 +14010,38 @@ def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocdatas(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocelem(store, elemtype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11897,29 +14055,59 @@ def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocelems(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -11948,8 +14136,6 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[$proj_uN_0(x).0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -11961,16 +14147,36 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = $allocmodule(store, module, var_0, var_1, var_2, var_3)) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_(dataidx : dataidx, data : data) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = $rundata_(dataidx, data)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_(elemidx : elemidx, elem : elem) : instr* @@ -11978,13 +14184,18 @@ def $runelem_(elemidx : elemidx, elem : elem) : instr* def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = $runelem_(elemidx, elem)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -11997,13 +14208,27 @@ def $evalexprs(state : state, expr*) : (state, ref*) def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) -- wf_state: `%`(z') } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprs(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 @@ -12017,6 +14242,21 @@ def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprss(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 def $evalglobals(state : state, globaltype*, expr*) : (state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 @@ -12027,12 +14267,27 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- let{s : store, f : frame} `%;%`_state(s, f) = z' -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $evalglobals(state, var_0, var_1)) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate(store : store, module : module, externaddr*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -12056,7 +14311,6 @@ def $instantiate(store : store, module : module, externaddr*) : config -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} @@ -12071,15 +14325,34 @@ def $instantiate(store : store, module : module, externaddr*) : config -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = $instantiate(store, module, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke(store : store, funcaddr : funcaddr, val*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $invoke(store, funcaddr, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -12098,6 +14371,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -12142,11 +14423,23 @@ rec { def $concat_idctxt(idctxt*) : idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) } +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $concat_idctxt(var_0)) + -- wf_idctxt: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec relation Idctxt_ok: `|-%:OK`(idctxt) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -12165,6 +14458,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12279,6 +14583,19 @@ def $importsd(decl*) : import* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $importsd(var_0)) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 @@ -12292,6 +14609,19 @@ def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tagsd(var_0)) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 @@ -12305,6 +14635,19 @@ def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsd(var_0)) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 @@ -12318,6 +14661,19 @@ def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsd(var_0)) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 @@ -12331,6 +14687,19 @@ def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesd(var_0)) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 @@ -12344,6 +14713,19 @@ def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $funcsd(var_0)) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 @@ -12357,6 +14739,19 @@ def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $datasd(var_0)) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 @@ -12370,6 +14765,19 @@ def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $elemsd(var_0)) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 @@ -12383,6 +14791,19 @@ def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $startsd(var_0)) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 def $exportsd(decl*) : export* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 @@ -12393,6 +14814,19 @@ def $exportsd(decl*) : export* def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) } +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $exportsd(var_0)) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} +} + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $ordered(decl*) : bool ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12598,6 +15032,7 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -13068,6 +15503,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -13093,6 +15536,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -13106,6 +15558,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -15470,7 +17935,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -15541,7 +18006,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -15550,7 +18015,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec diff --git a/spectec/test-middlend/specification.exp/10-sub-expansion.il b/spectec/test-middlend/specification.exp/10-pattern-simp.il similarity index 80% rename from spectec/test-middlend/specification.exp/10-sub-expansion.il rename to spectec/test-middlend/specification.exp/10-pattern-simp.il index 1662619723..e12b52fc25 100644 --- a/spectec/test-middlend/specification.exp/10-sub-expansion.il +++ b/spectec/test-middlend/specification.exp/10-pattern-simp.il @@ -69,7 +69,9 @@ def $concatn_(syntax X, X**, nat : nat) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2^n{w#2 <- `w*`}] ++ w'#2^n{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2*{w#2 <- `w*`}] ++ w'#2*{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + -- if (n = |`w*`|) + -- (if (n = |`w'*#2`|))*{`w'*#2` <- `w'**`} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -329,19 +331,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -402,23 +425,27 @@ def $utf8(char*) : byte* def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $utf8(var_0)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,10 +639,18 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { @@ -623,70 +658,162 @@ rec { def $free_list(free*) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 def $free_list{free : free, `free'*` : free*}([free] ++ free'#1*{free'#1 <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) } +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_list(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -701,6 +828,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -1065,73 +1201,157 @@ syntax Cnn = def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1170,6 +1390,7 @@ relation wf_limits: `%`(limits) rule limits_case_0{u64 : u64, `u64?` : u64?}: `%`(`[%..%]`_limits(u64, `u64?`)) -- wf_uN: `%%`(64, u64) + -- (wf_uN: `%%`(64, u64))?{u64 <- `u64?`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax tagtype = typeuse @@ -1475,10 +1696,17 @@ def $unpack(storagetype : storagetype) : valtype def $unpack(I32_storagetype) = I32_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I8_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I16_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? @@ -1544,10 +1772,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#1?{null_1#1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#2?{null_1#2 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? @@ -1585,6 +1821,19 @@ def $globalsxt(externtype*) : globaltype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsxt(var_0)) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 @@ -1598,6 +1847,19 @@ def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsxt(var_0)) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 @@ -1611,6 +1873,19 @@ def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesxt(var_0)) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 def $funcsxt(externtype*) : deftype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 @@ -1637,7 +1912,22 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($subst_typevar(typevar, var_0, var_1))) + -- wf_typeuse: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1646,11 +1936,25 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#2*{tv'#2 <- `tv'*`}, tu'#2*{tu'#2 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1693,188 +1997,389 @@ def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, $subst_heaptype(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I32_valtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}) = ($subst_numtype(I32_numtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}) : numtype <: valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I32_valtype, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}) = ($subst_numtype(I32_numtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}) : numtype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I64_valtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}) = ($subst_numtype(I64_numtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}) : numtype <: valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I64_valtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}) = ($subst_numtype(I64_numtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}) : numtype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F32_valtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}) = ($subst_numtype(F32_numtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}) : numtype <: valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F32_valtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}) = ($subst_numtype(F32_numtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}) : numtype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F64_valtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}) = ($subst_numtype(F64_numtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}) : numtype <: valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F64_valtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}) = ($subst_numtype(F64_numtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}) : numtype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(V128_valtype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}) = ($subst_vectype(V128_vectype, tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}) : vectype <: valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(V128_valtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}) = ($subst_vectype(V128_vectype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}) : vectype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_valtype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}) = ($subst_reftype(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}) : reftype <: valtype) + def $subst_valtype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_valtype(`null?`, heaptype), tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}) = ($subst_reftype(REF_reftype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}) : reftype <: valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}) = BOT_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_storagetype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}) = ($subst_valtype(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_storagetype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}) = ($subst_valtype(BOT_valtype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_storagetype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}) = ($subst_valtype(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_storagetype(`null?`, heaptype), tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}) = ($subst_valtype(REF_valtype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(V128_storagetype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}) = ($subst_valtype(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(V128_storagetype, tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}) = ($subst_valtype(V128_valtype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F64_storagetype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}) = ($subst_valtype(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F64_storagetype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}) = ($subst_valtype(F64_valtype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F32_storagetype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}) = ($subst_valtype(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F32_storagetype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}) = ($subst_valtype(F32_valtype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I64_storagetype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}) = ($subst_valtype(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I64_storagetype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}) = ($subst_valtype(I64_valtype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I32_storagetype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}) = ($subst_valtype(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}) : valtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I32_storagetype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}) = ($subst_valtype(I32_valtype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}) : valtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I8_storagetype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}) = ($subst_packtype(I8_packtype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}) : packtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I8_storagetype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}) = ($subst_packtype(I8_packtype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}) : packtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I16_storagetype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}) = ($subst_packtype(I16_packtype, tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}) : packtype <: storagetype) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I16_storagetype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}) = ($subst_packtype(I16_packtype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}) : packtype <: storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, $subst_storagetype(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}))) + def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`})*{ft#2 <- `ft*`}))) + def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}))) + def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`})*{t_1#2 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`})*{t_2#2 <- `t_2*`}))) + def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, $subst_typeuse(tu'#4, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`})*{tu'#4 <- `tu'*`}, $subst_comptype(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}))) + def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#5*{tu'#5 <- `tu'*`}) = !($minus_recs(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`})) + def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#4*{tu'#4 <- `tu'*`}) = !($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) + def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typeuse(typeuse, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_heaptype(heaptype, var_0, var_1)) + -- wf_heaptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_reftype(reftype, var_0, var_1)) + -- wf_reftype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_valtype(valtype, var_0, var_1)) + -- wf_valtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_storagetype(storagetype, var_0, var_1)) + -- wf_storagetype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_fieldtype(fieldtype, var_0, var_1)) + -- wf_fieldtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_comptype(comptype, var_0, var_1)) + -- wf_comptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_subtype(subtype, var_0, var_1)) + -- wf_subtype: `%`(ret_val) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}) = at + def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}) = at ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, $subst_valtype(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}))) + def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut#2?{mut#2 <- `mut?`}, t), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_globaltype(globaltype, var_0, var_1)) + -- wf_globaltype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#72*{tv#72 <- `tv*`}, tu#72*{tu#72 <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}) = `%%PAGE`_memtype(at, lim) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}))) + def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_tabletype(tabletype, var_0, var_1)) + -- wf_tabletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}))) + def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}))) + def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}))) + def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}))) + def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}))) + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_externtype(externtype, var_0, var_1)) + -- wf_externtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#85*{tv#85 <- `tv*`}, tu#85*{tu#85 <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`})*{xt_1#2 <- `xt_1*`}, $subst_externtype(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`})*{xt_2#2 <- `xt_2*`})) + def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_moduletype(moduletype, var_0, var_1)) + -- wf_moduletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu#88^n{tu#88 <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $free_moduletype(moduletype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = | mk_num__0(Inn : Inn, var_x : iN) @@ -2671,7 +3409,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4353,7 +5099,6 @@ relation wf_instr: `%`(instr) `%`(VEXTRACT_LANE_instr(shape, `sx?`, laneidx)) -- wf_shape: `%`(shape) -- wf_uN: `%%`(8, laneidx) - -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 @@ -4426,38 +5171,67 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) - -- wf_instr: `%`(CONST_instr(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) - -- wf_instr: `%`(CONST_instr(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) - -- wf_instr: `%`(CONST_instr(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`((consttype : consttype <: storagetype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) + def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype#504?{valtype#504 <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $free_blocktype(blocktype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4469,6 +5243,15 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { @@ -4480,7 +5263,6 @@ def $shift_labelidxs(labelidx*) : labelidx* def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}) = [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4490,15 +5272,12 @@ rec { def $free_instr(instr : instr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) + def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype#505*{valtype#505 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 @@ -4527,7 +5306,6 @@ def $free_instr(instr : instr) : free def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 @@ -4538,7 +5316,6 @@ def $free_instr(instr : instr) : free def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 @@ -4601,13 +5378,10 @@ def $free_instr(instr : instr) : free def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 @@ -4616,10 +5390,8 @@ def $free_instr(instr : instr) : free def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 @@ -4644,7 +5416,6 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 @@ -4655,10 +5426,8 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 @@ -4717,11 +5486,42 @@ def $free_block(instr*) : free -- let{free : free} free = $free_list($free_instr(instr#5)*{instr#5 <- `instr*`}) } +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = $free_instr(instr)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_block(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr(expr : expr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr{`instr*` : instr*}(instr#6*{instr#6 <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = $free_expr(expr)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = | ACTIVE(tableidx : tableidx, expr : expr) @@ -4912,85 +5712,216 @@ def $free_type(type : type) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free}: + `%%`(type, ret_val) + -- if (ret_val = $free_type(type)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag(tag : tag) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = $free_tag(tag)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global(global : global) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = $free_global(global)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table(table : table) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = $free_table(table)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local(local : local) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = $free_local(local)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func(func : func) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = $free_func(func)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(datamode : datamode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = $free_datamode(datamode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data(data : data) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode)) = $free_datamode(datamode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_data_is_wf: `%%`(data : data, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_data_is_wf_0{data : data, ret_val : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = $free_data(data)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(elemmode : elemmode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = $free_elemmode(elemmode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem(elem : elem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elem_is_wf_0{elem : elem, ret_val : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = $free_elem(elem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import(import : import) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = $free_import(import)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module(module : module) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = $free_module(module)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $funcidx_module(module : module) : funcidx* ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec @@ -5076,6 +6007,21 @@ def $with_locals(context : context, localidx*, localtype*) : context? ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($with_locals(context, var_0, var_1))) + -- wf_context: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 def $clos_deftypes(deftype*) : deftype* ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 @@ -5091,6 +6037,16 @@ def $clos_valtype(context : context, valtype : valtype) : valtype def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $clos_valtype(context, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_deftype(context : context, deftype : deftype) : deftype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -5109,12 +6065,32 @@ def $clos_externtype(context : context, externtype : externtype) : externtype def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = $clos_externtype(context, externtype)) + -- wf_externtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype(context : context, moduletype : moduletype) : moduletype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $clos_moduletype(context, moduletype)) + -- wf_moduletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5160,6 +6136,7 @@ relation Expand: `%~~%`(deftype, comptype) rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: `%~~%`(deftype, comptype) -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`($unrolldt(deftype)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -5185,6 +6162,16 @@ def $unrollht_(context : context, heaptype : heaptype) : subtype ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = $unrollht_(context, heaptype)) + -- wf_subtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5249,7 +6236,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5257,7 +6243,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) -- wf_context: `%`(C) -- wf_subtype: `%`(st) @@ -5334,12 +6319,11 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- if (|`comptype'*`| = |`typeuse*`|) - -- if (|`comptype'*`| = |`typeuse'**`|) -- (if ($unrollht_(C, (typeuse : typeuse <: heaptype)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrollht_(C, (typeuse : typeuse <: heaptype))))*{typeuse <- `typeuse*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} @@ -5369,13 +6353,13 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) -- if (i < n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- if (n = |`subtype*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} -- wf_context: `%`(C) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) @@ -5410,9 +6394,9 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: `%|-%<:%`(C, deftype_1, deftype_2) -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |typeuse*{typeuse <- `typeuse*`}|) -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) -- wf_context: `%`(C) + -- wf_subtype: `%`($unrolldt(deftype_1)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5495,7 +6479,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype), heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5504,7 +6487,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, heaptype, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype)) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5513,7 +6495,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5523,7 +6504,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5533,7 +6513,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5543,8 +6522,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: `%|-%<:%`(C, REC_heaptype(i), (typeuse*{typeuse <- `typeuse*`}[j] : typeuse <: heaptype)) - -- if (j < |typeuse*{typeuse <- `typeuse*`}|) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5653,7 +6630,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`t_1*`| = |`t_2*`|) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} @@ -5711,8 +6687,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`lct*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- `lct*`} @@ -5730,7 +6704,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) @@ -5754,13 +6727,11 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- if (|`comptype'*`| = |`yy**`|) - -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} -- (if ($unrolldt(C.TYPES_context[$proj_uN_0(x).0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrolldt(C.TYPES_context[$proj_uN_0(x).0])))*{x <- `x*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} @@ -5884,11 +6855,10 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) - -- if (|`t*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -6017,7 +6987,6 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) @@ -6029,10 +6998,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) @@ -6041,10 +7007,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) @@ -6053,7 +7016,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) @@ -6061,7 +7023,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) @@ -6070,35 +7031,38 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I32_valtype) = ?(?(CONST_val((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I64_valtype) = ?(?(CONST_val((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F32_valtype) = ?(?(CONST_val((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $fzero($size((F32_Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $fzero($size((F32_Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F64_valtype) = ?(?(CONST_val((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $fzero($size((F64_Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $fzero($size((F64_Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%DEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6200,7 +7164,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6211,7 +7174,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, `t*` : valtype*}: `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) @@ -6220,9 +7182,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]))*{l <- `l*`} - -- if ($proj_uN_0(l').0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l').0]) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6232,7 +7192,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) @@ -6242,7 +7201,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -6251,7 +7209,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6265,7 +7222,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6273,13 +7229,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) @@ -6289,7 +7245,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) @@ -6299,10 +7254,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) @@ -6324,7 +7277,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6339,7 +7291,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6354,10 +7305,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6374,8 +7323,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6416,9 +7363,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule `ref.func`{C : context, x : idx, dt : deftype}: `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) - -- if (|C.REFS_context| > 0) -- if (x <- C.REFS_context) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) @@ -6484,7 +7429,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) @@ -6494,10 +7438,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6505,9 +7449,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6519,9 +7461,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) @@ -6532,7 +7472,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) @@ -6542,10 +7481,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6553,7 +7492,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -6563,9 +7501,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) @@ -6575,12 +7511,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6588,7 +7523,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6599,7 +7533,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule `array.set`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) @@ -6616,7 +7549,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule `array.fill`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) @@ -6626,9 +7558,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) @@ -6640,9 +7570,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Storagetype_sub: `%|-%<:%`(C, (C.ELEMS_context[$proj_uN_0(y).0] : reftype <: storagetype), zt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) @@ -6652,12 +7580,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6681,7 +7608,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule `local.get`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) @@ -6691,7 +7617,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule `local.set`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) @@ -6701,7 +7626,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule `local.tee`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) @@ -6711,7 +7635,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -6721,7 +7644,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule `global.set`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) @@ -6731,7 +7653,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GET`_instr(x)) @@ -6741,7 +7662,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -6751,7 +7671,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) @@ -6761,7 +7680,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GROW`_instr(x)) @@ -6771,7 +7689,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) @@ -6781,9 +7698,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6795,9 +7710,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6809,7 +7722,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule `elem.drop`{C : context, x : idx, rt : reftype}: `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) @@ -6819,7 +7731,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) @@ -6829,7 +7740,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) @@ -6839,7 +7749,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) @@ -6849,9 +7758,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) @@ -6862,9 +7769,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) @@ -6874,7 +7779,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule `data.drop`{C : context, x : idx}: `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) @@ -6883,7 +7787,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -6894,7 +7797,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -6905,7 +7807,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -6916,7 +7817,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -6927,7 +7827,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -6938,7 +7837,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) -- wf_context: `%`(C) @@ -6949,7 +7847,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -6960,7 +7857,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -6971,7 +7867,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -6983,7 +7878,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -6994,7 +7888,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -7141,6 +8034,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -7156,6 +8050,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) @@ -7164,6 +8059,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) @@ -7214,15 +8110,12 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -7266,9 +8159,9 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7347,7 +8240,6 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule `global.get`{C : context, x : idx, t : valtype}: `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -7356,9 +8248,7 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, Inn : Inn, binop : binop_}: `%|-%CONST`(C, BINOP_instr((Inn : addrtype <: numtype), binop)) - -- if (|[I32_Inn I64_Inn]| > 0) -- if (Inn <- [I32_Inn I64_Inn]) - -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr((Inn : addrtype <: numtype), binop)) @@ -7405,6 +8295,7 @@ relation Tag_ok: `%|-%:%`(context, tag, tagtype) `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`($clos_tagtype(C, tagtype)) -- wf_tag: `%`(TAG_tag(tagtype)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7463,9 +8354,7 @@ relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[$proj_uN_0(x).0]) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`lct*`| = |`local*`|) -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- wf_context: `%`(C) @@ -7484,7 +8373,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) -- wf_context: `%`(C) @@ -7519,7 +8407,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) @@ -7544,7 +8431,6 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) @@ -7557,6 +8443,7 @@ relation Import_ok: `%|-%:%`(context, import, externtype) `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`($clos_externtype(C, xt)) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7564,7 +8451,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) @@ -7573,7 +8459,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) @@ -7582,7 +8467,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) @@ -7591,7 +8475,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) @@ -7600,7 +8483,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype((dt : deftype <: typeuse))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) @@ -7677,7 +8559,6 @@ relation wf_nonfuncs: `%`(nonfuncs) def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#3*{export#3 <- `export*`}))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -7685,24 +8566,15 @@ relation Module_ok: `|-%:%`(module, moduletype) rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) - -- if (|`import*`| = |`xt_I*`|) -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} - -- if (|`jt*`| = |`tag*`|) -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- if (|`mem*`| = |`mt*`|) -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} - -- if (|`table*`| = |`tt*`|) -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} - -- if (|`dt*`| = |`func*`|) -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} - -- if (|`data*`| = |`ok*`|) -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} - -- if (|`elem*`| = |`rt*`|) -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} - -- if (|`export*`| = |`nm*`|) - -- if (|`export*`| = |`xt_E*`|) -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7716,6 +8588,12 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`($clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + -- (wf_uN: `%%`(32, iter))*{iter <- $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))} + -- (wf_typeuse: `%`(iter))*{iter <- $tagsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_globaltype: `%`(iter))*{iter <- $globalsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_memtype: `%`(iter))*{iter <- $memsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_tabletype: `%`(iter))*{iter <- $tablesxt(xt_I*{xt_I <- `xt_I*`})} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7769,81 +8647,272 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`((Cnn : Cnn <: storagetype), ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $signed_(N : N, nat : nat) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7885,22 +8954,24 @@ def $sx(storagetype : storagetype) : sx?? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((I32_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I32_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((I64_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I64_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((I8_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I8_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((I16_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I16_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F32_lanetype) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $fzero($size((F32_Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $fzero($size((F32_Fnn : Fnn <: numtype)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F64_lanetype) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $fzero($size((F64_Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $fzero($size((F64_Fnn : Fnn <: numtype)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7929,7 +9000,6 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN @@ -7949,28 +9019,23 @@ def $ipopcnt_(N : N, iN : iN) : iN def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ M)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7978,7 +9043,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -7986,7 +9050,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? -- if ((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -7994,13 +9057,11 @@ def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) -- if ((j_1 = $signed_(N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8028,19 +9089,15 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8091,140 +9148,323 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fneg_(N : N, fN : fN) : fN* +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* +def $fneg_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* +def $fsqrt_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* +def $fceil_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* +def $ffloor_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* +def $ftrunc_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* +def $fnearest_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* +def $fadd_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +def $fsub_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 +def $fmul_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 +def $fdiv_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 +def $fmin_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fge_(N : N, fN : fN, fN : fN) : u32 +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmin_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fcopysign_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $feq_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fne_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $flt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fgt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fle_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -8243,38 +9483,77 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) - -- wf_lane_: `%%`((I32_numtype : numtype <: lanetype), mk_lane__0_lane_(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) - -- wf_lane_: `%%`((I64_numtype : numtype <: lanetype), mk_lane__0_lane_(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) - -- wf_lane_: `%%`((F32_numtype : numtype <: lanetype), mk_lane__0_lane_(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) - -- wf_lane_: `%%`((F64_numtype : numtype <: lanetype), mk_lane__0_lane_(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack((I8_packtype : packtype <: lanetype))), $psize(I8_packtype), c)) - -- wf_lane_: `%%`((I8_packtype : packtype <: lanetype), mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack((I8_packtype : packtype <: lanetype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack((I16_packtype : packtype <: lanetype))), $psize(I16_packtype), c)) - -- wf_lane_: `%%`((I16_packtype : packtype <: lanetype), mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack((I16_packtype : packtype <: lanetype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8290,10 +9569,18 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack((I8_packtype : packtype <: lanetype))), $psize(I8_packtype), c)) - -- wf_lit_: `%%`((I8_packtype : packtype <: storagetype), mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack((I8_packtype : packtype <: lanetype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack((I16_packtype : packtype <: lanetype))), $psize(I16_packtype), c)) - -- wf_lit_: `%%`((I16_packtype : packtype <: storagetype), mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack((I16_packtype : packtype <: lanetype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -8307,10 +9594,17 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack((I8_packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((I8_packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack((I8_packtype : packtype <: lanetype))), U_sx, c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack((I16_packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((I16_packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack((I16_packtype : packtype <: lanetype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8326,196 +9620,165 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack((I8_packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((I8_packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack((I8_packtype : packtype <: lanetype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack((I16_packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((I16_packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack((I16_packtype : packtype <: lanetype))), U_sx, c)))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`((!($cunpack(storagetype)) : consttype <: storagetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iclz_($sizenn((I32_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $iclz_($sizenn((I32_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iclz_($sizenn((I64_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $iclz_($sizenn((I64_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ictz_($sizenn((I32_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ictz_($sizenn((I32_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ictz_($sizenn((I64_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ictz_($sizenn((I64_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn((I32_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn((I32_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn((I64_Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn((I64_Inn : addrtype <: numtype)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{M : nat, i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iextend_($sizenn((I32_Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $iextend_($sizenn((I32_Inn : addrtype <: numtype)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{M : nat, i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iextend_($sizenn((I64_Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $iextend_($sizenn((I64_Inn : addrtype <: numtype)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#1)))*{iter_0#1 <- $fabs_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#1)*{iter_0#1 <- $fabs_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fabs_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#3)))*{iter_0#3 <- $fabs_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#3)*{iter_0#3 <- $fneg_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#6)*{iter_0#6 <- $fneg_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#5)))*{iter_0#5 <- $fneg_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fneg_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fneg_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#7)))*{iter_0#7 <- $fneg_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#5)*{iter_0#5 <- $fsqrt_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#10)*{iter_0#10 <- $fsqrt_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#9)))*{iter_0#9 <- $fsqrt_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#6)*{iter_0#6 <- $fsqrt_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $fsqrt_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#11)))*{iter_0#11 <- $fsqrt_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#7)*{iter_0#7 <- $fceil_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#14)*{iter_0#14 <- $fceil_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#13)))*{iter_0#13 <- $fceil_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fceil_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#16)*{iter_0#16 <- $fceil_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#15)))*{iter_0#15 <- $fceil_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#9)*{iter_0#9 <- $ffloor_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#18)*{iter_0#18 <- $ffloor_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#17)))*{iter_0#17 <- $ffloor_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#10)*{iter_0#10 <- $ffloor_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $ffloor_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#19)))*{iter_0#19 <- $ffloor_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#11)*{iter_0#11 <- $ftrunc_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#22)*{iter_0#22 <- $ftrunc_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#21)))*{iter_0#21 <- $ftrunc_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $ftrunc_($sizenn((F64_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $ftrunc_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#23)))*{iter_0#23 <- $ftrunc_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#13)*{iter_0#13 <- $fnearest_($sizenn((F32_Fnn : Fnn <: numtype)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#26)*{iter_0#26 <- $fnearest_($sizenn((F32_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#25)))*{iter_0#25 <- $fnearest_($sizenn((F32_Fnn : Fnn <: numtype)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#14)*{iter_0#14 <- $fnearest_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fnearest_($sizenn((F64_Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#27)))*{iter_0#27 <- $fnearest_($sizenn((F64_Fnn : Fnn <: numtype)), f)} + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $unop_(numtype, unop_, num_)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iadd_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $iadd_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iadd_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $iadd_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $isub_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $isub_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $isub_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $isub_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $imul_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $imul_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $imul_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $imul_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#30)*{iter_0#30 <- lift($idiv_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift($idiv_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#15)*{iter_0#15 <- lift($idiv_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#32)*{iter_0#32 <- lift($idiv_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift($idiv_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#16)*{iter_0#16 <- lift($idiv_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($irem_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift($irem_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#17)*{iter_0#17 <- lift($irem_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($irem_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift($irem_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#18)*{iter_0#18 <- lift($irem_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iand_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $iand_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iand_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $iand_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ior_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ior_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ior_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ior_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ixor_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ixor_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ixor_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ixor_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishl_($sizenn((I32_Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ishl_($sizenn((I32_Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishl_($sizenn((I64_Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ishl_($sizenn((I64_Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishr_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $ishr_($sizenn((I32_Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishr_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $ishr_($sizenn((I64_Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotl_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $irotl_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotl_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $irotl_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotr_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $irotr_($sizenn((I32_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotr_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $irotr_($sizenn((I64_Inn : addrtype <: numtype)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#38)*{iter_0#38 <- $fadd_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#37)))*{iter_0#37 <- $fadd_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#19)*{iter_0#19 <- $fadd_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $fadd_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#40)*{iter_0#40 <- $fadd_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#39)))*{iter_0#39 <- $fadd_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#21)*{iter_0#21 <- $fsub_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $fsub_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#41)))*{iter_0#41 <- $fsub_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#22)*{iter_0#22 <- $fsub_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $fsub_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#43)))*{iter_0#43 <- $fsub_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#23)*{iter_0#23 <- $fmul_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $fmul_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#45)))*{iter_0#45 <- $fmul_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $fmul_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $fmul_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#47)))*{iter_0#47 <- $fmul_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#25)*{iter_0#25 <- $fdiv_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#50)*{iter_0#50 <- $fdiv_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#49)))*{iter_0#49 <- $fdiv_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#26)*{iter_0#26 <- $fdiv_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#52)*{iter_0#52 <- $fdiv_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#51)))*{iter_0#51 <- $fdiv_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#27)*{iter_0#27 <- $fmin_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#54)*{iter_0#54 <- $fmin_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#53)))*{iter_0#53 <- $fmin_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fmin_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#56)*{iter_0#56 <- $fmin_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#55)))*{iter_0#55 <- $fmin_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#29)*{iter_0#29 <- $fmax_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#58)*{iter_0#58 <- $fmax_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#57)))*{iter_0#57 <- $fmax_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#30)*{iter_0#30 <- $fmax_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#60)*{iter_0#60 <- $fmax_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#59)))*{iter_0#59 <- $fmax_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#31)*{iter_0#31 <- $fcopysign_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#62)*{iter_0#62 <- $fcopysign_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#61)))*{iter_0#61 <- $fcopysign_($sizenn((F32_Fnn : Fnn <: numtype)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#32)*{iter_0#32 <- $fcopysign_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#64)*{iter_0#64 <- $fcopysign_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#63)))*{iter_0#63 <- $fcopysign_($sizenn((F64_Fnn : Fnn <: numtype)), f_1, f_2)} + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = $binop_(numtype, binop_, num_, num__0)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -8579,324 +9842,500 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $extend__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $extend__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $extend__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $extend__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $wrap__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, $wrap__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $wrap__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, $wrap__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#66)*{iter_0#66 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#65)))*{iter_0#65 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#33)*{iter_0#33 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#68)*{iter_0#68 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#67)))*{iter_0#67 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#70)*{iter_0#70 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#69)))*{iter_0#69 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#35)*{iter_0#35 <- lift($trunc__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#72)*{iter_0#72 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#71)))*{iter_0#71 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($trunc__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#74)*{iter_0#74 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#73)))*{iter_0#73 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#37)*{iter_0#37 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#76)*{iter_0#76 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, iter_0#75)))*{iter_0#75 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#38)*{iter_0#38 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I32_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#78)*{iter_0#78 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#77)))*{iter_0#77 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#39)*{iter_0#39 <- lift($trunc_sat__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#80)*{iter_0#80 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, iter_0#79)))*{iter_0#79 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#40)*{iter_0#40 <- lift($trunc_sat__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((I64_Inn : addrtype <: numtype)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $convert__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, $convert__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $convert__($sizenn1((I32_Inn : addrtype <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, $convert__($sizenn1((I64_Inn : addrtype <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#82)*{iter_0#82 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#81)))*{iter_0#81 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#41)*{iter_0#41 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#84)*{iter_0#84 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#83)))*{iter_0#83 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#86)*{iter_0#86 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#85)))*{iter_0#85 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#43)*{iter_0#43 <- $promote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#88)*{iter_0#88 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#87)))*{iter_0#87 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $promote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#90)*{iter_0#90 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#89)))*{iter_0#89 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#45)*{iter_0#45 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#92)*{iter_0#92 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#91)))*{iter_0#91 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F32_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#94)*{iter_0#94 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#93)))*{iter_0#93 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#47)*{iter_0#47 <- $demote__($sizenn1((F32_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#96)*{iter_0#96 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#95)))*{iter_0#95 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $demote__($sizenn1((F64_Fnn : Fnn <: numtype)), $sizenn2((F64_Fnn : Fnn <: numtype)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__((I32_Inn : addrtype <: numtype), (F32_Fnn : Fnn <: numtype), mk_num__0_num_(I32_Inn, i_1))] -- if ($size((I32_Inn : addrtype <: numtype)) = $size((F32_Fnn : Fnn <: numtype))) - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__((I64_Inn : addrtype <: numtype), (F32_Fnn : Fnn <: numtype), mk_num__0_num_(I64_Inn, i_1))] -- if ($size((I64_Inn : addrtype <: numtype)) = $size((F32_Fnn : Fnn <: numtype))) - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__((I32_Inn : addrtype <: numtype), (F64_Fnn : Fnn <: numtype), mk_num__0_num_(I32_Inn, i_1))] -- if ($size((I32_Inn : addrtype <: numtype)) = $size((F64_Fnn : Fnn <: numtype))) - -- wf_num_: `%%`((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__((I64_Inn : addrtype <: numtype), (F64_Fnn : Fnn <: numtype), mk_num__0_num_(I64_Inn, i_1))] -- if ($size((I64_Inn : addrtype <: numtype)) = $size((F64_Fnn : Fnn <: numtype))) - -- wf_num_: `%%`((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__((F32_Fnn : Fnn <: numtype), (I32_Inn : addrtype <: numtype), mk_num__1_num_(F32_Fnn, f_1))] -- if ($size((F32_Fnn : Fnn <: numtype)) = $size((I32_Inn : addrtype <: numtype))) - -- wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__((F64_Fnn : Fnn <: numtype), (I32_Inn : addrtype <: numtype), mk_num__1_num_(F64_Fnn, f_1))] -- if ($size((F64_Fnn : Fnn <: numtype)) = $size((I32_Inn : addrtype <: numtype))) - -- wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__((F32_Fnn : Fnn <: numtype), (I64_Inn : addrtype <: numtype), mk_num__1_num_(F32_Fnn, f_1))] -- if ($size((F32_Fnn : Fnn <: numtype)) = $size((I64_Inn : addrtype <: numtype))) - -- wf_num_: `%%`((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__((F64_Fnn : Fnn <: numtype), (I64_Inn : addrtype <: numtype), mk_num__1_num_(F64_Fnn, f_1))] -- if ($size((F64_Fnn : Fnn <: numtype)) = $size((I64_Inn : addrtype <: numtype))) - -- wf_num_: `%%`((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $cvtop__(numtype_1, numtype_2, cvtop__, num_)) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`}))) = zero#3442?{zero#3442 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`}))) = zero#3442?{zero#3442 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`}))) = zero#3444?{zero#3444 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`}))) = zero#3444?{zero#3444 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`}))) = zero#3446?{zero#3446 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`}))) = zero#3446?{zero#3446 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`}))) = zero#3448?{zero#3448 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`}))) = zero#3448?{zero#3448 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`}))) = zero#3450?{zero#3450 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`}))) = zero#3450?{zero#3450 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`}))) = zero#3452?{zero#3452 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`}))) = zero#3452?{zero#3452 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`}))) = zero#3454?{zero#3454 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`}))) = zero#3454?{zero#3454 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`}))) = zero#3456?{zero#3456 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`}))) = zero#3456?{zero#3456 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`}))) = zero#3458?{zero#3458 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`}))) = zero#3458?{zero#3458 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`}))) = zero#3460?{zero#3460 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`}))) = zero#3460?{zero#3460 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`}))) = zero#3462?{zero#3462 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`}))) = zero#3462?{zero#3462 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`}))) = zero#3464?{zero#3464 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`}))) = zero#3464?{zero#3464 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`}))) = zero#3466?{zero#3466 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`}))) = zero#3466?{zero#3466 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`}))) = zero#3468?{zero#3468 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`}))) = zero#3468?{zero#3468 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`}))) = zero#3470?{zero#3470 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`}))) = zero#3470?{zero#3470 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`}))) = zero#3472?{zero#3472 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`}))) = zero#3472?{zero#3472 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx))) = half#3046?{half#3046 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx))) = half#3046?{half#3046 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx))) = half#3048?{half#3048 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx))) = half#3048?{half#3048 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx))) = half#3050?{half#3050 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx))) = half#3050?{half#3050 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx))) = half#3052?{half#3052 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx))) = half#3052?{half#3052 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx))) = half#3054?{half#3054 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx))) = half#3054?{half#3054 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx))) = half#3056?{half#3056 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx))) = half#3056?{half#3056 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx))) = half#3058?{half#3058 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx))) = half#3058?{half#3058 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx))) = half#3060?{half#3060 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx))) = half#3060?{half#3060 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $half(half : half, nat : nat, nat : nat) : nat @@ -8909,366 +10348,332 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#1*{c#1 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if ($signed_(N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#5)*{c#5 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#4)*{c#4 <- `c*`})] -- let{`c_1*` : lane_*} c_1#1*{c_1#1 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c*` : iN*} c#3*{c#3 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#2)))*{c_1#2 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#4)))*{c#4 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#8)*{c#8 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#6)*{c#6 <- `c*`})] -- let{`c_1*` : lane_*} c_1#3*{c_1#3 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#6*{c#6 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} + -- let{`c*` : iN*} c#5*{c#5 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#7)))*{c#7 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#11)*{c#11 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#8)*{c#8 <- `c*`})] -- let{`c_1*` : lane_*} c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} + -- let{`c*` : iN*} c#7*{c#7 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#10)))*{c#10 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#14)*{c#14 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#10)*{c#10 <- `c*`})] -- let{`c_1*` : lane_*} c_1#7*{c_1#7 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#12*{c#12 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} + -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#13)))*{c#13 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#16*{c#16 <- `c*#2`})*{`c*#2` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#12*{c#12 <- `c*#2`})*{`c*#2` <- `c**`} -- let{`c_1*` : lane_*} c_1#9*{c_1#9 <- `c_1*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#15*{c#15 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#97))*{iter_0#97 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) + -- let{`c**` : lane_**} c#11*{c#11 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#49))*{iter_0#49 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#98))))*{iter_0#98 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} + -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#50))))*{iter_0#50 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#18*{c#18 <- `c*#4`})*{`c*#4` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#14*{c#14 <- `c*#4`})*{`c*#4` <- `c**`} -- let{`c_1*` : lane_*} c_1#12*{c_1#12 <- `c_1*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#17*{c#17 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#99))*{iter_0#99 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) + -- let{`c**` : lane_**} c#13*{c#13 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#51))*{iter_0#51 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#100))))*{iter_0#100 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} + -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#52))))*{iter_0#52 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#21)*{c#21 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#16)*{c#16 <- `c*`})] -- let{`c_1*` : lane_*} c_1#15*{c_1#15 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#1*{c_2#1 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} + -- let{`c*` : iN*} c#15*{c#15 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#20)))*{c#20 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#24)*{c#24 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#18)*{c#18 <- `c*`})] -- let{`c_1*` : lane_*} c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#3*{c_2#3 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#22*{c#22 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} + -- let{`c*` : iN*} c#17*{c#17 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#23)))*{c#23 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#27)*{c#27 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#20)*{c#20 <- `c*`})] -- let{`c_1*` : lane_*} c_1#19*{c_1#19 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} + -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#26)))*{c#26 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#22)*{c#22 <- `c*`})] -- let{`c_1*` : lane_*} c_1#21*{c_1#21 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#7*{c_2#7 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#28*{c#28 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} + -- let{`c*` : iN*} c#21*{c#21 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#29)))*{c#29 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#33)*{c#33 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#24)*{c#24 <- `c*`})] -- let{`c_1*` : lane_*} c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#9*{c_2#9 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#31*{c#31 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} + -- let{`c*` : iN*} c#23*{c#23 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#32)))*{c#32 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#36)*{c#36 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#26)*{c#26 <- `c*`})] -- let{`c_1*` : lane_*} c_1#25*{c_1#25 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#34*{c#34 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} + -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#35)))*{c#35 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#39)*{c#39 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#28)*{c#28 <- `c*`})] -- let{`c_1*` : lane_*} c_1#27*{c_1#27 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#13*{c_2#13 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#37*{c#37 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} + -- let{`c*` : iN*} c#27*{c#27 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#38)))*{c#38 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#42)*{c#42 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] -- let{`c_1*` : lane_*} c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#15*{c_2#15 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#40*{c#40 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} + -- let{`c*` : iN*} c#29*{c#29 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#41)))*{c#41 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#44*{c#44 <- `c*#6`})*{`c*#6` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#32*{c#32 <- `c*#6`})*{`c*#6` <- `c**`} -- let{`c_1*` : lane_*} c_1#31*{c_1#31 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#43*{c#43 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#101)*{iter_0#101 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) + -- let{`c**` : lane_**} c#31*{c#31 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#53)*{iter_0#53 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I32_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I32_Jnn, iter_0#102)))*{iter_0#102 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} + -- (wf_lane_: `%%`((I32_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I32_Jnn, iter_0#54)))*{iter_0#54 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#46*{c#46 <- `c*#8`})*{`c*#8` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#34*{c#34 <- `c*#8`})*{`c*#8` <- `c**`} -- let{`c_1*` : lane_*} c_1#34*{c_1#34 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#45*{c#45 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#103)*{iter_0#103 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) + -- let{`c**` : lane_**} c#33*{c#33 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#55)*{iter_0#55 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I64_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I64_Jnn, iter_0#104)))*{iter_0#104 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} + -- (wf_lane_: `%%`((I64_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I64_Jnn, iter_0#56)))*{iter_0#56 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#48*{c#48 <- `c*#10`})*{`c*#10` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#36*{c#36 <- `c*#10`})*{`c*#10` <- `c**`} -- let{`c_1*` : lane_*} c_1#37*{c_1#37 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#47*{c#47 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#105)*{iter_0#105 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) + -- let{`c**` : lane_**} c#35*{c#35 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#57)*{iter_0#57 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I8_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I8_Jnn, iter_0#106)))*{iter_0#106 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} + -- (wf_lane_: `%%`((I8_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I8_Jnn, iter_0#58)))*{iter_0#58 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#50*{c#50 <- `c*#12`})*{`c*#12` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#38*{c#38 <- `c*#12`})*{`c*#12` <- `c**`} -- let{`c_1*` : lane_*} c_1#40*{c_1#40 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#49*{c#49 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#107)*{iter_0#107 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) + -- let{`c**` : lane_**} c#37*{c#37 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#59)*{iter_0#59 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I16_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I16_Jnn, iter_0#108)))*{iter_0#108 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} + -- (wf_lane_: `%%`((I16_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I16_Jnn, iter_0#60)))*{iter_0#60 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#52*{c#52 <- `c*#14`})*{`c*#14` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#40*{c#40 <- `c*#14`})*{`c*#14` <- `c**`} -- let{`c_1*` : lane_*} c_1#43*{c_1#43 <- `c_1*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#51*{c#51 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#109))*{iter_0#109 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) + -- let{`c**` : lane_**} c#39*{c#39 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#61))*{iter_0#61 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#110))))*{iter_0#110 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} + -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#62))))*{iter_0#62 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#54*{c#54 <- `c*#16`})*{`c*#16` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#42*{c#42 <- `c*#16`})*{`c*#16` <- `c**`} -- let{`c_1*` : lane_*} c_1#46*{c_1#46 <- `c_1*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#53*{c#53 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#111))*{iter_0#111 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) + -- let{`c**` : lane_**} c#41*{c#41 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#63))*{iter_0#63 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#112))))*{iter_0#112 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} + -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#64))))*{iter_0#64 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#56*{c#56 <- `c*#18`})*{`c*#18` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#44*{c#44 <- `c*#18`})*{`c*#18` <- `c**`} -- let{`c_1*` : lane_*} c_1#49*{c_1#49 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#1*{c_3#1 <- `c_3*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#55*{c#55 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#113)*{iter_0#113 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) + -- let{`c**` : lane_**} c#43*{c#43 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#65)*{iter_0#65 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I32_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I32_Jnn, iter_0#114)))*{iter_0#114 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} + -- (wf_lane_: `%%`((I32_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I32_Jnn, iter_0#66)))*{iter_0#66 <- $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#58*{c#58 <- `c*#20`})*{`c*#20` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#46*{c#46 <- `c*#20`})*{`c*#20` <- `c**`} -- let{`c_1*` : lane_*} c_1#52*{c_1#52 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#4*{c_3#4 <- `c_3*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#57*{c#57 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#115)*{iter_0#115 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) + -- let{`c**` : lane_**} c#45*{c#45 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#67)*{iter_0#67 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I64_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I64_Jnn, iter_0#116)))*{iter_0#116 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} + -- (wf_lane_: `%%`((I64_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I64_Jnn, iter_0#68)))*{iter_0#68 <- $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#60*{c#60 <- `c*#22`})*{`c*#22` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#48*{c#48 <- `c*#22`})*{`c*#22` <- `c**`} -- let{`c_1*` : lane_*} c_1#55*{c_1#55 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#7*{c_3#7 <- `c_3*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#59*{c#59 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#117)*{iter_0#117 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) + -- let{`c**` : lane_**} c#47*{c#47 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#69)*{iter_0#69 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I8_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I8_Jnn, iter_0#118)))*{iter_0#118 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} + -- (wf_lane_: `%%`((I8_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I8_Jnn, iter_0#70)))*{iter_0#70 <- $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#62*{c#62 <- `c*#24`})*{`c*#24` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#50*{c#50 <- `c*#24`})*{`c*#24` <- `c**`} -- let{`c_1*` : lane_*} c_1#58*{c_1#58 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#10*{c_3#10 <- `c_3*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#61*{c#61 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#119)*{iter_0#119 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) + -- let{`c**` : lane_**} c#49*{c#49 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#71)*{iter_0#71 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((I16_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I16_Jnn, iter_0#120)))*{iter_0#120 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} + -- (wf_lane_: `%%`((I16_Jnn : Jnn <: lanetype), mk_lane__2_lane_(I16_Jnn, iter_0#72)))*{iter_0#72 <- $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#64*{c#64 <- `c*#26`})*{`c*#26` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), c#52*{c#52 <- `c*#26`})*{`c*#26` <- `c**`} -- let{`c_1*` : lane_*} c_1#61*{c_1#61 <- `c_1*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#13*{c_3#13 <- `c_3*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#63*{c#63 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#121))*{iter_0#121 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) + -- let{`c**` : lane_**} c#51*{c#51 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#73))*{iter_0#73 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#122))))*{iter_0#122 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} + -- (wf_lane_: `%%`((F32_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, iter_0#74))))*{iter_0#74 <- $f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#66*{c#66 <- `c*#28`})*{`c*#28` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), c#54*{c#54 <- `c*#28`})*{`c*#28` <- `c**`} -- let{`c_1*` : lane_*} c_1#64*{c_1#64 <- `c_1*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#16*{c_3#16 <- `c_3*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#65*{c#65 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#123))*{iter_0#123 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) + -- let{`c**` : lane_**} c#53*{c#53 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#75))*{iter_0#75 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#124))))*{iter_0#124 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} + -- (wf_lane_: `%%`((F64_Fnn : Fnn <: lanetype), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, iter_0#76))))*{iter_0#76 <- $f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#69)*{c#69 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#56)*{c#56 <- `c*`}) -- let{`c_1*` : lane_*} c_1#67*{c_1#67 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} + -- let{`c*` : iN*} c#55*{c#55 <- `c*`} = $extend__(1, $lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#68)))*{c#68 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- `c_1*`, c_2#55 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#72)*{c#72 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#58)*{c#58 <- `c*`}) -- let{`c_1*` : lane_*} c_1#70*{c_1#70 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#70*{c#70 <- `c*`} = $extend__(1, $lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} + -- let{`c*` : iN*} c#57*{c#57 <- `c*`} = $extend__(1, $lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#71)))*{c#71 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- `c_1*`, c_2#58 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#75)*{c#75 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#60)*{c#60 <- `c*`}) -- let{`c_1*` : lane_*} c_1#73*{c_1#73 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} + -- let{`c*` : iN*} c#59*{c#59 <- `c*`} = $extend__(1, $lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#74)))*{c#74 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- `c_1*`, c_2#61 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#78)*{c#78 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#62)*{c#62 <- `c*`}) -- let{`c_1*` : lane_*} c_1#76*{c_1#76 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#76*{c#76 <- `c*`} = $extend__(1, $lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} + -- let{`c*` : iN*} c#61*{c#61 <- `c*`} = $extend__(1, $lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#77)))*{c#77 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- `c_1*`, c_2#64 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#81)*{c#81 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#64)*{c#64 <- `c*`}) -- let{`c_1*` : lane_*} c_1#79*{c_1#79 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $extend__(1, $lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} + -- let{`c*` : iN*} c#63*{c#63 <- `c*`} = $extend__(1, $lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#80)))*{c#80 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- `c_1*`, c_2#67 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#84)*{c#84 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#66)*{c#66 <- `c*`}) -- let{`c_1*` : lane_*} c_1#82*{c_1#82 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#82*{c#82 <- `c*`} = $extend__(1, $lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} + -- let{`c*` : iN*} c#65*{c#65 <- `c*`} = $extend__(1, $lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#83)))*{c#83 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- `c_1*`, c_2#70 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#87)*{c#87 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#68)*{c#68 <- `c*`}) -- let{`c_1*` : lane_*} c_1#85*{c_1#85 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $extend__(1, $lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} + -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#86)))*{c#86 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- `c_1*`, c_2#73 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#70)*{c#70 <- `c*`}) -- let{`c_1*` : lane_*} c_1#88*{c_1#88 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#88*{c#88 <- `c*`} = $extend__(1, $lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} + -- let{`c*` : iN*} c#69*{c#69 <- `c*`} = $extend__(1, $lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#89)))*{c#89 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- `c_1*`, c_2#76 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#93).0)))*{c#93 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#72).0)))*{c#72 <- `c*`}) -- let{`c_1*` : lane_*} c_1#91*{c_1#91 <- `c_1*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $extend__(1, $sizenn((F32_Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} + -- let{`c*` : iN*} c#71*{c#71 <- `c*`} = $extend__(1, $sizenn((F32_Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} -- if ($isize(Inn) = $fsize(F32_Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#92).0)))))*{c#92 <- `c*`} -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn((F32_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- `c_1*`, c_2#79 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#96).0)))*{c#96 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#74).0)))*{c#74 <- `c*`}) -- let{`c_1*` : lane_*} c_1#94*{c_1#94 <- `c_1*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#94*{c#94 <- `c*`} = $extend__(1, $sizenn((F64_Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} + -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $sizenn((F64_Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} -- if ($isize(Inn) = $fsize(F64_Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#95).0)))))*{c#95 <- `c*`} -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn((F64_Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- `c_1*`, c_2#82 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#99)*{c#99 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#76)*{c#76 <- `c*`}) -- let{`c_1*` : lane_*} c_1#97*{c_1#97 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} + -- let{`c*` : iN*} c#75*{c#75 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#98)))*{c#98 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#102)*{c#102 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#78)*{c#78 <- `c*`}) -- let{`c_1*` : lane_*} c_1#99*{c_1#99 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#100*{c#100 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} + -- let{`c*` : iN*} c#77*{c#77 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#101)))*{c#101 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#105)*{c#105 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#80)*{c#80 <- `c*`}) -- let{`c_1*` : lane_*} c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#103*{c#103 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} + -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#104)))*{c#104 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#108)*{c#108 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#82)*{c#82 <- `c*`}) -- let{`c_1*` : lane_*} c_1#103*{c_1#103 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#106*{c#106 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} + -- let{`c*` : iN*} c#81*{c#81 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#107)))*{c#107 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#111)*{c#111 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#84)*{c#84 <- `c*`}) -- let{`c_1*` : lane_*} c_1#105*{c_1#105 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#109*{c#109 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} + -- let{`c*` : iN*} c#83*{c#83 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#110)))*{c#110 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#114)*{c#114 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#86)*{c#86 <- `c*`}) -- let{`c_1*` : lane_*} c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#112*{c#112 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} + -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#113)))*{c#113 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#117)*{c#117 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#88)*{c#88 <- `c*`}) -- let{`c_1*` : lane_*} c_1#109*{c_1#109 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#115*{c#115 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} + -- let{`c*` : iN*} c#87*{c#87 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#116)))*{c#116 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#120)*{c#120 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) -- let{`c_1*` : lane_*} c_1#111*{c_1#111 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#118*{c#118 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} + -- let{`c*` : iN*} c#89*{c#89 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#119)))*{c#119 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 @@ -9276,7 +10681,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((I32_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9284,7 +10688,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((I64_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9292,7 +10695,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((I8_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9300,7 +10702,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((I16_Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9308,59 +10709,55 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#123)*{c#123 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#92)*{c#92 <- `c*`}) -- let{`c_1*` : lane_*} c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#121*{c#121 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} + -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $f_($lsizenn((I32_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#122)))*{c#122 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#126)*{c#126 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#94)*{c#94 <- `c*`}) -- let{`c_1*` : lane_*} c_1#127*{c_1#127 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#85*{c_2#85 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#124*{c#124 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} + -- let{`c*` : iN*} c#93*{c#93 <- `c*`} = $f_($lsizenn((I64_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#125)))*{c#125 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#129)*{c#129 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#96)*{c#96 <- `c*`}) -- let{`c_1*` : lane_*} c_1#129*{c_1#129 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#87*{c_2#87 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#127*{c#127 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} + -- let{`c*` : iN*} c#95*{c#95 <- `c*`} = $f_($lsizenn((I8_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#128)))*{c#128 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#132)*{c#132 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#98)*{c#98 <- `c*`}) -- let{`c_1*` : lane_*} c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#130*{c#130 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} + -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn((I16_Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#131)))*{c#131 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139139*{i#139139 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#134*{c#134 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139040*{i#139040 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), c#100*{c#100 <- `c*`}) -- let{`c_1*` : lane_*} c_1#133*{c_1#133 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#91*{c_2#91 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#133*{c#133 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139142).0]*{i#139142 <- `i*`} + -- let{`c*` : lane_*} c#99*{c#99 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139043).0]*{i#139043 <- `i*`} -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139146*{i#139146 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#136*{c#136 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139047*{i#139047 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), c#102*{c#102 <- `c*`}) -- let{`c_1*` : lane_*} c_1#135*{c_1#135 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#93*{c_2#93 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#135*{c#135 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139149).0]*{i#139149 <- `i*`} + -- let{`c*` : lane_*} c#101*{c#101 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139050).0]*{i#139050 <- `i*`} -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139153*{i#139153 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#138*{c#138 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139054*{i#139054 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), c#104*{c#104 <- `c*`}) -- let{`c_1*` : lane_*} c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#137*{c#137 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139156).0]*{i#139156 <- `i*`} + -- let{`c*` : lane_*} c#103*{c#103 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139057).0]*{i#139057 <- `i*`} -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139160*{i#139160 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#140*{c#140 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139061*{i#139061 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), c#106*{c#106 <- `c*`}) -- let{`c_1*` : lane_*} c_1#139*{c_1#139 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#97*{c_2#97 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#139*{c#139 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139163).0]*{i#139163 <- `i*`} + -- let{`c*` : lane_*} c#105*{c#105 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139064).0]*{i#139064 <- `i*`} -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -9387,782 +10784,859 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#143))?{c#143 <- `c?`}) - -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#142))))?{c#142 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`}) - -- let{`c?` : iN?} c#144?{c#144 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#145))))?{c#145 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#149))?{c#149 <- `c?`}) - -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#148))))?{c#148 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#152))?{c#152 <- `c?`}) - -- let{`c?` : iN?} c#150?{c#150 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#151))))?{c#151 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#155))?{c#155 <- `c?`}) - -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#154))))?{c#154 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#158))?{c#158 <- `c?`}) - -- let{`c?` : iN?} c#156?{c#156 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#157))))?{c#157 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#161))?{c#161 <- `c?`}) - -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#160))))?{c#160 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`}) - -- let{`c?` : iN?} c#162?{c#162 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#163))))?{c#163 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#167))?{c#167 <- `c?`}) - -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#166))))?{c#166 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#170))?{c#170 <- `c?`}) - -- let{`c?` : iN?} c#168?{c#168 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#169))))?{c#169 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#173))?{c#173 <- `c?`}) - -- let{`c?` : iN?} c#171?{c#171 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#172))))?{c#172 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#176))?{c#176 <- `c?`}) - -- let{`c?` : iN?} c#174?{c#174 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#175))))?{c#175 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#179))?{c#179 <- `c?`}) - -- let{`c?` : iN?} c#177?{c#177 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#178))))?{c#178 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#182))?{c#182 <- `c?`}) - -- let{`c?` : iN?} c#180?{c#180 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#181))))?{c#181 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#185))?{c#185 <- `c?`}) - -- let{`c?` : iN?} c#183?{c#183 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#184))))?{c#184 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#188))?{c#188 <- `c?`}) - -- let{`c?` : iN?} c#186?{c#186 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#187))))?{c#187 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#191))?{c#191 <- `c?`}) - -- let{`c?` : iN?} c#189?{c#189 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#190))))?{c#190 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#194))?{c#194 <- `c?`}) - -- let{`c?` : iN?} c#192?{c#192 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#193))))?{c#193 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#197))?{c#197 <- `c?`}) - -- let{`c?` : iN?} c#195?{c#195 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#196))))?{c#196 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#200))?{c#200 <- `c?`}) - -- let{`c?` : iN?} c#198?{c#198 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#199))))?{c#199 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#203))?{c#203 <- `c?`}) - -- let{`c?` : iN?} c#201?{c#201 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#202))))?{c#202 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#206))?{c#206 <- `c?`}) - -- let{`c?` : iN?} c#204?{c#204 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#205))))?{c#205 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#209))?{c#209 <- `c?`}) - -- let{`c?` : iN?} c#207?{c#207 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#208))))?{c#208 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#212))?{c#212 <- `c?`}) - -- let{`c?` : iN?} c#210?{c#210 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#211))))?{c#211 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#215))?{c#215 <- `c?`}) - -- let{`c?` : iN?} c#213?{c#213 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#214))))?{c#214 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#218))?{c#218 <- `c?`}) - -- let{`c?` : iN?} c#216?{c#216 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#217))))?{c#217 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#221))?{c#221 <- `c?`}) - -- let{`c?` : iN?} c#219?{c#219 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#220))))?{c#220 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#224))?{c#224 <- `c?`}) - -- let{`c?` : iN?} c#222?{c#222 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#223))))?{c#223 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#227))?{c#227 <- `c?`}) - -- let{`c?` : iN?} c#225?{c#225 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#226))))?{c#226 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#230))?{c#230 <- `c?`}) - -- let{`c?` : iN?} c#228?{c#228 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#229))))?{c#229 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#233))?{c#233 <- `c?`}) - -- let{`c?` : iN?} c#231?{c#231 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#232))))?{c#232 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#236))?{c#236 <- `c?`}) - -- let{`c?` : iN?} c#234?{c#234 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Inn : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#235))))?{c#235 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#239))*{c#239 <- `c*`} - -- let{`c*` : fN*} c#237*{c#237 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#238))))*{c#238 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#242))*{c#242 <- `c*`} - -- let{`c*` : fN*} c#240*{c#240 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#241))))*{c#241 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#245))*{c#245 <- `c*`} - -- let{`c*` : fN*} c#243*{c#243 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#244))))*{c#244 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#248))*{c#248 <- `c*`} - -- let{`c*` : fN*} c#246*{c#246 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#247))))*{c#247 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#251))*{c#251 <- `c*`} - -- let{`c*` : fN*} c#249*{c#249 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#250))))*{c#250 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#254))*{c#254 <- `c*`} - -- let{`c*` : fN*} c#252*{c#252 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#253))))*{c#253 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#257))*{c#257 <- `c*`} - -- let{`c*` : fN*} c#255*{c#255 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#256))))*{c#256 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#260))*{c#260 <- `c*`} - -- let{`c*` : fN*} c#258*{c#258 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#259))))*{c#259 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#263))*{c#263 <- `c*`} - -- let{`c*` : fN*} c#261*{c#261 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#262))))*{c#262 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#266))*{c#266 <- `c*`} - -- let{`c*` : fN*} c#264*{c#264 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#265))))*{c#265 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#269))*{c#269 <- `c*`} - -- let{`c*` : fN*} c#267*{c#267 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#268))))*{c#268 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#272))*{c#272 <- `c*`} - -- let{`c*` : fN*} c#270*{c#270 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#271))))*{c#271 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#275))*{c#275 <- `c*`} - -- let{`c*` : fN*} c#273*{c#273 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#274))))*{c#274 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#278))*{c#278 <- `c*`} - -- let{`c*` : fN*} c#276*{c#276 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F32_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#277))))*{c#277 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#281))*{c#281 <- `c*`} - -- let{`c*` : fN*} c#279*{c#279 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#280))))*{c#280 <- `c*`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#108))?{c#108 <- `c?`}) + -- let{`c?` : iN?} c#107?{c#107 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#110))?{c#110 <- `c?`}) + -- let{`c?` : iN?} c#109?{c#109 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#112))?{c#112 <- `c?`}) + -- let{`c?` : iN?} c#111?{c#111 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#114))?{c#114 <- `c?`}) + -- let{`c?` : iN?} c#113?{c#113 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#116))?{c#116 <- `c?`}) + -- let{`c?` : iN?} c#115?{c#115 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#118))?{c#118 <- `c?`}) + -- let{`c?` : iN?} c#117?{c#117 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#120))?{c#120 <- `c?`}) + -- let{`c?` : iN?} c#119?{c#119 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#122))?{c#122 <- `c?`}) + -- let{`c?` : iN?} c#121?{c#121 <- `c?`} = $trunc_sat__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#124))?{c#124 <- `c?`}) + -- let{`c?` : iN?} c#123?{c#123 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#126))?{c#126 <- `c?`}) + -- let{`c?` : iN?} c#125?{c#125 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#128))?{c#128 <- `c?`}) + -- let{`c?` : iN?} c#127?{c#127 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#130))?{c#130 <- `c?`}) + -- let{`c?` : iN?} c#129?{c#129 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#132))?{c#132 <- `c?`}) + -- let{`c?` : iN?} c#131?{c#131 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#134))?{c#134 <- `c?`}) + -- let{`c?` : iN?} c#133?{c#133 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#136))?{c#136 <- `c?`}) + -- let{`c?` : iN?} c#135?{c#135 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#138))?{c#138 <- `c?`}) + -- let{`c?` : iN?} c#137?{c#137 <- `c?`} = $trunc_sat__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#140))?{c#140 <- `c?`}) + -- let{`c?` : iN?} c#139?{c#139 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#142))?{c#142 <- `c?`}) + -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#144))?{c#144 <- `c?`}) + -- let{`c?` : iN?} c#143?{c#143 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`}) + -- let{`c?` : iN?} c#145?{c#145 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#148))?{c#148 <- `c?`}) + -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#150))?{c#150 <- `c?`}) + -- let{`c?` : iN?} c#149?{c#149 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#152))?{c#152 <- `c?`}) + -- let{`c?` : iN?} c#151?{c#151 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#154))?{c#154 <- `c?`}) + -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $relaxed_trunc__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#156))?{c#156 <- `c?`}) + -- let{`c?` : iN?} c#155?{c#155 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#158))?{c#158 <- `c?`}) + -- let{`c?` : iN?} c#157?{c#157 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#160))?{c#160 <- `c?`}) + -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I32_Inn : addrtype <: numtype), mk_num__0_num_(I32_Inn, c#162))?{c#162 <- `c?`}) + -- let{`c?` : iN?} c#161?{c#161 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I32_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`}) + -- let{`c?` : iN?} c#163?{c#163 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#166))?{c#166 <- `c?`}) + -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#168))?{c#168 <- `c?`}) + -- let{`c?` : iN?} c#167?{c#167 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_((I64_Inn : addrtype <: numtype), mk_num__0_num_(I64_Inn, c#170))?{c#170 <- `c?`}) + -- let{`c?` : iN?} c#169?{c#169 <- `c?`} = $relaxed_trunc__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((I64_Inn : addrtype <: lanetype)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#172))*{c#172 <- `c*`} + -- let{`c*` : fN*} c#171*{c#171 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#174))*{c#174 <- `c*`} + -- let{`c*` : fN*} c#173*{c#173 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#176))*{c#176 <- `c*`} + -- let{`c*` : fN*} c#175*{c#175 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#178))*{c#178 <- `c*`} + -- let{`c*` : fN*} c#177*{c#177 <- `c*`} = $demote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#180))*{c#180 <- `c*`} + -- let{`c*` : fN*} c#179*{c#179 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#182))*{c#182 <- `c*`} + -- let{`c*` : fN*} c#181*{c#181 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#184))*{c#184 <- `c*`} + -- let{`c*` : fN*} c#183*{c#183 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#186))*{c#186 <- `c*`} + -- let{`c*` : fN*} c#185*{c#185 <- `c*`} = $demote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#188))*{c#188 <- `c*`} + -- let{`c*` : fN*} c#187*{c#187 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#190))*{c#190 <- `c*`} + -- let{`c*` : fN*} c#189*{c#189 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#192))*{c#192 <- `c*`} + -- let{`c*` : fN*} c#191*{c#191 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#194))*{c#194 <- `c*`} + -- let{`c*` : fN*} c#193*{c#193 <- `c*`} = $promote__($lsizenn1((F32_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#196))*{c#196 <- `c*`} + -- let{`c*` : fN*} c#195*{c#195 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F32_Fnn : Fnn <: numtype), mk_num__1_num_(F32_Fnn, c#198))*{c#198 <- `c*`} + -- let{`c*` : fN*} c#197*{c#197 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F32_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#200))*{c#200 <- `c*`} + -- let{`c*` : fN*} c#199*{c#199 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#202))*{c#202 <- `c*`} + -- let{`c*` : fN*} c#201*{c#201 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#284))*{c#284 <- `c*`} - -- let{`c*` : fN*} c#282*{c#282 <- `c*`} = $promote__($lsizenn1((F64_Fnn : Fnn <: lanetype)), $lsizenn2((F64_Fnn : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((F64_Fnn : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((F64_Fnn : Fnn <: numtype), mk_num__1_num_(F64_Fnn, c#283))))*{c#283 <- `c*`} + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = $lcvtop__(shape_1, shape_2, vcvtop__, lane_)) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v + def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M_0)), vcvtop, v_1) = v -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) -- let{`c_1*` : lane_*} c_1#141*{c_1#141 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#285*{c#285 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142)*{c_1#142 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#286*{c#286 <- `c*#30`})*{`c*#30` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#203*{c#203 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142)*{c_1#142 <- `c_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) -- let{`c_1*` : lane_*} c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c#287*{c#287 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#288*{c#288 <- `c*#32`})*{`c*#32` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#205*{c#205 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- `c_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) -- let{`c_1*` : lane_*} c_1#145*{c_1#145 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c#289*{c#289 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#290*{c#290 <- `c*#34`})*{`c*#34` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#207*{c#207 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139845*{i#139845 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139530*{i#139530 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ @@ -10346,386 +11820,316 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139991*{i#139991 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139992).0*{i#139992 <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1#2)))*{j_1#2 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2#2)))*{j_2#2 <- `j_2*`} + def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139675*{i#139675 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139676).0*{i#139676 <- `i*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#293)*{c#293 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#210)*{c#210 <- `c*`}) -- let{`c_1*` : lane_*} c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#49*{c'_1#49 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`} - -- let{`c*` : iN*} c#291*{c#291 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#50*{c'_1#50 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#292)))*{c#292 <- `c*`} + -- let{`c*` : iN*} c#209*{c#209 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#50*{c'_1#50 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#296)*{c#296 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#212)*{c#212 <- `c*`}) -- let{`c_1*` : lane_*} c_1#181*{c_1#181 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#51*{c'_1#51 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- `c_1*`} - -- let{`c*` : iN*} c#294*{c#294 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#52*{c'_1#52 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#295)))*{c#295 <- `c*`} + -- let{`c*` : iN*} c#211*{c#211 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#52*{c'_1#52 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#299)*{c#299 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#214)*{c#214 <- `c*`}) -- let{`c_1*` : lane_*} c_1#183*{c_1#183 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- `c_1*`} - -- let{`c*` : iN*} c#297*{c#297 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#54*{c'_1#54 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#298)))*{c#298 <- `c*`} + -- let{`c*` : iN*} c#213*{c#213 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#54*{c'_1#54 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#302)*{c#302 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#216)*{c#216 <- `c*`}) -- let{`c_1*` : lane_*} c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#55*{c'_1#55 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`} - -- let{`c*` : iN*} c#300*{c#300 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#56*{c'_1#56 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#301)))*{c#301 <- `c*`} + -- let{`c*` : iN*} c#215*{c#215 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#56*{c'_1#56 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#305)*{c#305 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#218)*{c#218 <- `c*`}) -- let{`c_1*` : lane_*} c_1#187*{c_1#187 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#57*{c'_1#57 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- `c_1*`} - -- let{`c*` : iN*} c#303*{c#303 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#58*{c'_1#58 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#304)))*{c#304 <- `c*`} + -- let{`c*` : iN*} c#217*{c#217 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#58*{c'_1#58 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#308)*{c#308 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#220)*{c#220 <- `c*`}) -- let{`c_1*` : lane_*} c_1#189*{c_1#189 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- `c_1*`} - -- let{`c*` : iN*} c#306*{c#306 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#60*{c'_1#60 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#307)))*{c#307 <- `c*`} + -- let{`c*` : iN*} c#219*{c#219 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#60*{c'_1#60 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#311)*{c#311 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#222)*{c#222 <- `c*`}) -- let{`c_1*` : lane_*} c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#61*{c'_1#61 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`} - -- let{`c*` : iN*} c#309*{c#309 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#62*{c'_1#62 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#310)))*{c#310 <- `c*`} + -- let{`c*` : iN*} c#221*{c#221 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#62*{c'_1#62 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#314)*{c#314 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#224)*{c#224 <- `c*`}) -- let{`c_1*` : lane_*} c_1#193*{c_1#193 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#63*{c'_1#63 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- `c_1*`} - -- let{`c*` : iN*} c#312*{c#312 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#64*{c'_1#64 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#313)))*{c#313 <- `c*`} + -- let{`c*` : iN*} c#223*{c#223 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#64*{c'_1#64 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#317)*{c#317 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#226)*{c#226 <- `c*`}) -- let{`c_1*` : lane_*} c_1#195*{c_1#195 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- `c_1*`} - -- let{`c*` : iN*} c#315*{c#315 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#66*{c'_1#66 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#316)))*{c#316 <- `c*`} + -- let{`c*` : iN*} c#225*{c#225 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#66*{c'_1#66 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#320)*{c#320 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#228)*{c#228 <- `c*`}) -- let{`c_1*` : lane_*} c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#67*{c'_1#67 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`} - -- let{`c*` : iN*} c#318*{c#318 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#68*{c'_1#68 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#319)))*{c#319 <- `c*`} + -- let{`c*` : iN*} c#227*{c#227 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#68*{c'_1#68 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#323)*{c#323 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#230)*{c#230 <- `c*`}) -- let{`c_1*` : lane_*} c_1#199*{c_1#199 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#69*{c'_1#69 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- `c_1*`} - -- let{`c*` : iN*} c#321*{c#321 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#70*{c'_1#70 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#322)))*{c#322 <- `c*`} + -- let{`c*` : iN*} c#229*{c#229 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#70*{c'_1#70 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#326)*{c#326 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#232)*{c#232 <- `c*`}) -- let{`c_1*` : lane_*} c_1#201*{c_1#201 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- `c_1*`} - -- let{`c*` : iN*} c#324*{c#324 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#72*{c'_1#72 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#325)))*{c#325 <- `c*`} + -- let{`c*` : iN*} c#231*{c#231 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#72*{c'_1#72 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#329)*{c#329 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#234)*{c#234 <- `c*`}) -- let{`c_1*` : lane_*} c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#73*{c'_1#73 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`} - -- let{`c*` : iN*} c#327*{c#327 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#74*{c'_1#74 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#328)))*{c#328 <- `c*`} + -- let{`c*` : iN*} c#233*{c#233 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#74*{c'_1#74 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#332)*{c#332 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#236)*{c#236 <- `c*`}) -- let{`c_1*` : lane_*} c_1#205*{c_1#205 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#75*{c'_1#75 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- `c_1*`} - -- let{`c*` : iN*} c#330*{c#330 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#76*{c'_1#76 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#331)))*{c#331 <- `c*`} + -- let{`c*` : iN*} c#235*{c#235 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#76*{c'_1#76 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#335)*{c#335 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#238)*{c#238 <- `c*`}) -- let{`c_1*` : lane_*} c_1#207*{c_1#207 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- `c_1*`} - -- let{`c*` : iN*} c#333*{c#333 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#78*{c'_1#78 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#334)))*{c#334 <- `c*`} + -- let{`c*` : iN*} c#237*{c#237 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#78*{c'_1#78 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#338)*{c#338 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#240)*{c#240 <- `c*`}) -- let{`c_1*` : lane_*} c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#79*{c'_1#79 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`} - -- let{`c*` : iN*} c#336*{c#336 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#80*{c'_1#80 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#337)))*{c#337 <- `c*`} + -- let{`c*` : iN*} c#239*{c#239 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#80*{c'_1#80 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#1*{i_1#1 <- `i_1*`}, i_2#1*{i_2#1 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#4))*{j_1#4 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#4))*{j_2#4 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#3*{i_1#3 <- `i_1*`}, i_2#3*{i_2#3 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#5 j_2#5]*{j_1#5 <- `j_1*`, j_2#5 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#6))*{j_1#6 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#6))*{j_2#6 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#341)*{c#341 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#242)*{c#242 <- `c*`}) -- let{`c_1*` : lane_*} c_1#211*{c_1#211 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#81*{c'_1#81 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#49*{c'_2#49 <- `c'_2*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`} - -- let{`c*` : iN*} c#339*{c#339 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#340)))*{c#340 <- `c*`} + -- let{`c*` : iN*} c#241*{c#241 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#344)*{c#344 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#244)*{c#244 <- `c*`}) -- let{`c_1*` : lane_*} c_1#213*{c_1#213 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#133*{c_2#133 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#51*{c'_2#51 <- `c'_2*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- `c_2*`} - -- let{`c*` : iN*} c#342*{c#342 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#343)))*{c#343 <- `c*`} + -- let{`c*` : iN*} c#243*{c#243 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#347)*{c#347 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#246)*{c#246 <- `c*`}) -- let{`c_1*` : lane_*} c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#135*{c_2#135 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#85*{c'_1#85 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- `c_2*`} - -- let{`c*` : iN*} c#345*{c#345 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#346)))*{c#346 <- `c*`} + -- let{`c*` : iN*} c#245*{c#245 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#350)*{c#350 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#248)*{c#248 <- `c*`}) -- let{`c_1*` : lane_*} c_1#217*{c_1#217 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#87*{c'_1#87 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#55*{c'_2#55 <- `c'_2*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I32_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`} - -- let{`c*` : iN*} c#348*{c#348 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#349)))*{c#349 <- `c*`} + -- let{`c*` : iN*} c#247*{c#247 <- `c*`} = $f_($lsizenn2((I32_Jnn : Jnn <: lanetype)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#353)*{c#353 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#250)*{c#250 <- `c*`}) -- let{`c_1*` : lane_*} c_1#219*{c_1#219 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#139*{c_2#139 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#57*{c'_2#57 <- `c'_2*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- `c_2*`} - -- let{`c*` : iN*} c#351*{c#351 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#352)))*{c#352 <- `c*`} + -- let{`c*` : iN*} c#249*{c#249 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#356)*{c#356 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#252)*{c#252 <- `c*`}) -- let{`c_1*` : lane_*} c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#141*{c_2#141 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#91*{c'_1#91 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- `c_2*`} - -- let{`c*` : iN*} c#354*{c#354 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#355)))*{c#355 <- `c*`} + -- let{`c*` : iN*} c#251*{c#251 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#359)*{c#359 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#254)*{c#254 <- `c*`}) -- let{`c_1*` : lane_*} c_1#223*{c_1#223 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#93*{c'_1#93 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#61*{c'_2#61 <- `c'_2*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`} - -- let{`c*` : iN*} c#357*{c#357 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#358)))*{c#358 <- `c*`} + -- let{`c*` : iN*} c#253*{c#253 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#362)*{c#362 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#256)*{c#256 <- `c*`}) -- let{`c_1*` : lane_*} c_1#225*{c_1#225 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#145*{c_2#145 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#63*{c'_2#63 <- `c'_2*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I64_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- `c_2*`} - -- let{`c*` : iN*} c#360*{c#360 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#361)))*{c#361 <- `c*`} + -- let{`c*` : iN*} c#255*{c#255 <- `c*`} = $f_($lsizenn2((I64_Jnn : Jnn <: lanetype)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#365)*{c#365 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#258)*{c#258 <- `c*`}) -- let{`c_1*` : lane_*} c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#147*{c_2#147 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#97*{c'_1#97 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- `c_2*`} - -- let{`c*` : iN*} c#363*{c#363 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#364)))*{c#364 <- `c*`} + -- let{`c*` : iN*} c#257*{c#257 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#368)*{c#368 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#260)*{c#260 <- `c*`}) -- let{`c_1*` : lane_*} c_1#229*{c_1#229 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#99*{c'_1#99 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#67*{c'_2#67 <- `c'_2*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`} - -- let{`c*` : iN*} c#366*{c#366 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#367)))*{c#367 <- `c*`} + -- let{`c*` : iN*} c#259*{c#259 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#371)*{c#371 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#262)*{c#262 <- `c*`}) -- let{`c_1*` : lane_*} c_1#231*{c_1#231 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#151*{c_2#151 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#69*{c'_2#69 <- `c'_2*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- `c_2*`} - -- let{`c*` : iN*} c#369*{c#369 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#370)))*{c#370 <- `c*`} + -- let{`c*` : iN*} c#261*{c#261 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#374)*{c#374 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#264)*{c#264 <- `c*`}) -- let{`c_1*` : lane_*} c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#153*{c_2#153 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#103*{c'_1#103 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I8_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- `c_2*`} - -- let{`c*` : iN*} c#372*{c#372 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#373)))*{c#373 <- `c*`} + -- let{`c*` : iN*} c#263*{c#263 <- `c*`} = $f_($lsizenn2((I8_Jnn : Jnn <: lanetype)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#377)*{c#377 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#266)*{c#266 <- `c*`}) -- let{`c_1*` : lane_*} c_1#235*{c_1#235 <- `c_1*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#105*{c'_1#105 <- `c'_1*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#73*{c'_2#73 <- `c'_2*`} = $extend__($lsizenn1((I32_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`} - -- let{`c*` : iN*} c#375*{c#375 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#376)))*{c#376 <- `c*`} + -- let{`c*` : iN*} c#265*{c#265 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#380)*{c#380 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#268)*{c#268 <- `c*`}) -- let{`c_1*` : lane_*} c_1#237*{c_1#237 <- `c_1*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#157*{c_2#157 <- `c_2*`} = $lanes_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#75*{c'_2#75 <- `c'_2*`} = $extend__($lsizenn1((I64_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- `c_2*`} - -- let{`c*` : iN*} c#378*{c#378 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#379)))*{c#379 <- `c*`} + -- let{`c*` : iN*} c#267*{c#267 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#383)*{c#383 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#270)*{c#270 <- `c*`}) -- let{`c_1*` : lane_*} c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#159*{c_2#159 <- `c_2*`} = $lanes_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#109*{c'_1#109 <- `c'_1*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1((I8_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- `c_2*`} - -- let{`c*` : iN*} c#381*{c#381 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#382)))*{c#382 <- `c*`} + -- let{`c*` : iN*} c#269*{c#269 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#386)*{c#386 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#272)*{c#272 <- `c*`}) -- let{`c_1*` : lane_*} c_1#241*{c_1#241 <- `c_1*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#111*{c'_1#111 <- `c'_1*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#79*{c'_2#79 <- `c'_2*`} = $extend__($lsizenn1((I16_Jnn : Jnn <: lanetype)), $lsizenn2((I16_Jnn : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`} - -- let{`c*` : iN*} c#384*{c#384 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#385)))*{c#385 <- `c*`} + -- let{`c*` : iN*} c#271*{c#271 <- `c*`} = $f_($lsizenn2((I16_Jnn : Jnn <: lanetype)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -10736,304 +12140,207 @@ def $ivmul_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I32_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11041,14 +12348,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I64_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11056,14 +12364,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I8_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11071,14 +12380,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I16_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11086,14 +12396,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I32_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11101,14 +12412,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I64_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11116,14 +12428,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I8_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11131,14 +12444,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I16_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11146,14 +12460,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I32_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11161,14 +12476,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I64_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11176,14 +12492,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I8_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11191,14 +12508,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I16_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11206,14 +12524,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I32_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I32_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11221,14 +12540,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I64_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I64_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11236,14 +12556,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I8_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I8_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11251,14 +12572,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1((I16_Jnn : Jnn <: lanetype)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11266,6 +12588,8 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape((I16_Jnn : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11630,13 +12954,21 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval? def $packfield_{val : val}(I32_storagetype, val) = ?((val : val <: fieldval)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11781,13 +13113,21 @@ def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? def $unpackfield_{numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -11858,11 +13198,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11873,61 +13231,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11938,123 +13404,337 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b#1*{b#1 <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b#2*{b#2 <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r#1*{r#1 <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r#2*{r#2 <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#3*{b#3 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b#4*{b#4 <- `b*`}], $fof(z))) + def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#2*{b#2 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst{z : state, `si*` : structinst*}(z, si#1*{si#1 <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si#2*{si#2 <- `si*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai#1*{ai#1 <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai#2*{ai#2 <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn#1*{exn#1 <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn#2*{exn#2 <- `exn*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? @@ -12065,27 +13745,44 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !($growtable(tableinst, nat, ref))) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem(meminst : meminst, nat : nat) : meminst? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#7*{b#7 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#9*{b#9 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !($growmem(meminst, nat))) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -12124,7 +13821,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) @@ -12133,7 +13829,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) @@ -12142,7 +13837,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) @@ -12151,7 +13845,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) @@ -12246,7 +13939,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 rule tag{s : store, a : addr, taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) @@ -12254,7 +13946,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 rule global{s : store, a : addr, globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) @@ -12262,7 +13953,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 rule mem{s : store, a : addr, meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) @@ -12270,7 +13960,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 rule table{s : store, a : addr, tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) @@ -12278,7 +13967,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, funcinst : funcinst}: `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) @@ -12300,26 +13988,76 @@ def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $inst_valtype(moduleinst, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = $inst_reftype(moduleinst, reftype)) + -- wf_reftype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = $inst_globaltype(moduleinst, globaltype)) + -- wf_globaltype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $inst_memtype(moduleinst, memtype)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = $inst_tabletype(moduleinst, tabletype)) + -- wf_tabletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12354,7 +14092,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_1 : val <: instr)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12364,7 +14101,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_2 : val <: instr)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12374,7 +14110,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12383,7 +14118,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12399,6 +14133,7 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) -- if ($proj_uN_0(l).0 = 0) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: @@ -12416,7 +14151,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-true`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12425,7 +14159,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-false`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12434,7 +14167,6 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `br_table-lt`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])) @@ -12442,7 +14174,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) @@ -12500,11 +14231,13 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `frame-vals`{n : n, f : frame, `val*` : val*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})], (val : val <: instr)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: @@ -12559,7 +14292,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.i31`{i : num_}: `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`REF.I31`_instr) -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) @@ -12679,8 +14411,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (|$unop_(nt, unop, c_1)| > 0) -- if (c <- $unop_(nt, unop, c_1)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -12689,6 +14421,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) -- if ($unop_(nt, unop, c_1) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) @@ -12696,8 +14429,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -12707,6 +14440,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) -- if ($binop_(nt, binop, c_1, c_2) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -12715,8 +14449,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12724,8 +14458,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) @@ -12734,8 +14468,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (|$cvtop__(nt_1, nt_2, cvtop, c_1)| > 0) -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) @@ -12744,6 +14478,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) @@ -12751,8 +14486,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12760,8 +14495,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -12770,8 +14505,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12781,8 +14516,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12790,8 +14525,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vunop_(sh, vunop, c_1)| > 0) -- if (c <- $vunop_(sh, vunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12800,6 +14535,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) -- if ($vunop_(sh, vunop, c_1) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) @@ -12807,8 +14543,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -12818,6 +14554,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -12826,8 +14563,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vternop_(sh, vternop, c_1, c_2, c_3)| > 0) -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12838,6 +14575,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12848,10 +14586,10 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) - -- if ($proj_num__0(c) =/= ?()) - -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12861,6 +14599,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- wf_uN: `%%`(128, $vrelop_(sh, vrelop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) @@ -12869,8 +14608,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- wf_uN: `%%`(128, $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) @@ -12879,8 +14618,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, $vbitmaskop_(sh, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12889,6 +14628,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- wf_uN: `%%`(128, $vswizzlop_(sh, swizzlop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) @@ -12898,6 +14638,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- wf_uN: `%%`(128, $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) @@ -12907,6 +14648,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12915,8 +14658,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)|) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -12926,10 +14669,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) - -- if ($proj_num__0(c_2) =/= ?()) - -- if ($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)|) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -12939,6 +14681,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -12949,6 +14694,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- wf_uN: `%%`(128, $vextunop__(sh_1, sh_2, vextunop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12957,6 +14703,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- wf_uN: `%%`(128, $vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) @@ -12966,6 +14713,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- wf_uN: `%%`(128, $vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12976,6 +14724,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- wf_uN: `%%`(128, $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) @@ -12985,6 +14734,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- wf_uN: `%%`(128, $vcvtop__(sh_1, sh_2, vcvtop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12993,12 +14743,20 @@ relation Step_pure: `%~>%`(instr*, instr*) def $blocktype_(state : state, blocktype : blocktype) : instrtype ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), [], `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#2*{t_1#2 <- `t_1*`}), `%`_resulttype(t_2#2*{t_2#2 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t#1?{t#1 <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t#2?{t#2 <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $blocktype_(state, blocktype)) + -- wf_instrtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) @@ -13006,6 +14764,7 @@ relation `Step_read_before_br_on_cast-fail`: `%`(config) rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -13015,6 +14774,7 @@ relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13035,11 +14795,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13047,11 +14806,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -13060,8 +14818,8 @@ relation `Step_read_before_table.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13070,9 +14828,9 @@ relation `Step_read_before_table.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13088,9 +14846,9 @@ relation `Step_read_before_table.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13100,8 +14858,6 @@ relation `Step_read_before_table.copy-gt`: `%`(config) rule `table.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) @@ -13123,9 +14879,9 @@ relation `Step_read_before_table.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13134,9 +14890,9 @@ relation `Step_read_before_table.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13145,8 +14901,8 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13155,9 +14911,9 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13173,9 +14929,9 @@ relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13184,9 +14940,9 @@ relation `Step_read_before_memory.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13196,6 +14952,7 @@ relation `Step_read_before_ref.test-false`: `%`(config) rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -13205,6 +14962,7 @@ relation `Step_read_before_ref.cast-fail`: `%`(config) rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13212,9 +14970,25 @@ relation `Step_read_before_array.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13223,18 +14997,16 @@ relation `Step_read_before_array.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13250,18 +15022,16 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13272,9 +15042,6 @@ relation `Step_read_before_array.copy-gt`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -13299,18 +15066,16 @@ relation `Step_read_before_array.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13319,17 +15084,41 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13339,9 +15128,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13349,9 +15137,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13368,9 +15155,8 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13378,9 +15164,8 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13390,22 +15175,31 @@ relation Step_read: `%~>%`(config, instr*) rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -13419,6 +15213,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13431,9 +15226,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -13447,24 +15241,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) - -- if (a < |$funcinst(z)|) -- if ($funcinst(z)[a] = fi) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) @@ -13490,12 +15285,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) - -- if (a < |$funcinst(z)|) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-null`{z : state}: @@ -13535,22 +15333,20 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13579,15 +15375,20 @@ relation Step_read: `%~>%`(config, instr*) rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13595,13 +15396,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13609,7 +15411,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0] : ref <: instr)]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) - -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13617,6 +15419,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -13624,15 +15427,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13640,7 +15442,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13653,9 +15454,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13669,8 +15470,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) @@ -13686,8 +15485,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) @@ -13702,17 +15499,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) @@ -13720,11 +15515,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -13736,86 +15529,94 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -13824,37 +15625,42 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) @@ -13865,6 +15671,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -13872,15 +15679,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -13888,7 +15694,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -13901,17 +15706,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) @@ -13919,8 +15722,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) @@ -13937,8 +15738,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) @@ -13955,17 +15754,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -13973,9 +15770,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -13996,7 +15790,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.func`{z : state, x : idx}: `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) @@ -14004,6 +15797,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -14018,6 +15812,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14031,10 +15826,10 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), (val : val <: instr)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`val*`| = |`zt*`|) - -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- `zt*`} -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14048,11 +15843,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])) : val <: instr)]) - -- if ($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) - -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) - -- if (a < |$structinst(z)|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14060,9 +15853,10 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14070,27 +15864,27 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- if (n = |`ref*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(i) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14098,15 +15892,18 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- (if ($cunpack(zt) =/= ?()))^n{} -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zsize(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (n = |`c*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -14117,20 +15914,17 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])) : val <: instr)]) - -- if ($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if (a < |$arrayinst(z)|) - -- if ($proj_num__0(i) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14143,7 +15937,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-array`{z : state, a : addr}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) - -- if (a < |$arrayinst(z)|) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) @@ -14156,28 +15949,22 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (n =/= 0) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14201,45 +15988,31 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (n =/= 0) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14257,11 +16030,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_array.copy-gt`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14285,43 +16055,33 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ($proj_num__0(j) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14340,9 +16100,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -14350,9 +16109,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14367,14 +16125,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- if ($cunpack(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- ~ `Step_read_before_array.init_data-num`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`((!($cunpack(zt)) : consttype <: storagetype), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14444,15 +16202,17 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (n = |`val*`|) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule `local.set`{z : state, val : val, x : idx}: @@ -14469,24 +16229,25 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) -- if (ti = !($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`(!($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) @@ -14505,69 +16266,67 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(c) =/= ?()) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if ($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) - -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)|) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) @@ -14575,8 +16334,9 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) -- if (mi = !($growmem($mem(z, x), n))) + -- wf_meminst: `%`(!($growmem($mem(z, x), n))) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) @@ -14597,12 +16357,17 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- if (n = |`val*`|) + -- if (n = |`mut?*`|) + -- if (n = |`zt*`|) + -- if (n = |`val*`|) + -- if (n = |`zt*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: @@ -14613,8 +16378,6 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) - -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) @@ -14624,12 +16387,13 @@ relation Step: `%~>%`(config, config) rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: @@ -14640,17 +16404,14 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($packfield_(zt, val) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) @@ -14707,9 +16468,18 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = $alloctag(store, tagtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14723,14 +16493,38 @@ def $alloctags(store : store, tagtype*) : (store, tagaddr*) -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = $alloctags(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $alloctags(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = $allocglobal(store, globaltype, val)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14744,14 +16538,38 @@ def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = $allocglobals(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $allocglobals(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $allocmem(store, memtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14765,14 +16583,38 @@ def $allocmems(store : store, memtype*) : (store, memaddr*) -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = $allocmems(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocmems(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = $alloctable(store, tabletype, ref)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14786,14 +16628,39 @@ def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = $alloctables(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $alloctables(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = $allocfunc(store, deftype, funccode, moduleinst)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14807,14 +16674,38 @@ def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funca -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = $allocfuncs(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = $allocfuncs(store, var_0, var_1, var_2)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte#2*{byte#2 <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) -- if (datainst = {BYTES byte#3*{byte#3 <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte#4*{byte#4 <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocdata(store, datatype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14823,19 +16714,43 @@ def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 def $allocdatas{s : store}(s, [], []) = (s, []) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#10*{b#10 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b#11*{b#11 <- `b*`}) + def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#8*{b#8 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) + -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b#9*{b#9 <- `b*`}) -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = $allocdatas(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocdatas(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref#1*{ref#1 <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) -- if (eleminst = {TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocelem(store, elemtype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14849,41 +16764,71 @@ def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = $allocelems(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocelems(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#4*{export#4 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#3*{export#3 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#4*{global#4 <- `global*`}), `%`_list(mem#4*{mem#4 <- `mem*`}), `%`_list(table#4*{table#4 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#4*{elem#4 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#5*{export#5 <- `export*`})) = module + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#4*{export#4 <- `export*`})) = module -- if (tag#3*{tag#3 <- `tag*`} = TAG_tag(tagtype#78)*{tagtype#78 <- `tagtype*`}) - -- if (global#5*{global#5 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) - -- if (mem#5*{mem#5 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) - -- if (table#5*{table#5 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) + -- if (global#4*{global#4 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) + -- if (mem#4*{mem#4 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) + -- if (table#4*{table#4 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) -- if (func#4*{func#4 <- `func*`} = FUNC_func(x#2, local#2*{local#2 <- `local*#82`}, expr_F#1)*{expr_F#1 <- `expr_F*`, `local*#82` <- `local**`, x#2 <- `x*`}) -- if (data#3*{data#3 <- `data*`} = DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`}) - -- if (elem#5*{elem#5 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) + -- if (elem#4*{elem#4 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`}) -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`}) -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`}) @@ -14898,11 +16843,9 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = $allocdatas(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}) -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype#2, (dt#13 : deftype <: typeuse)*{dt#13 <- `dt*`})*{elemtype#2 <- `elemtype*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}) -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = $allocfuncs(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{})) - -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#6*{export#6 <- `export*`})) + -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#5*{export#5 <- `export*`})) -- if (moduleinst = {TYPES dt#15*{dt#15 <- `dt*`}, TAGS aa_I#3*{aa_I#3 <- `aa_I*`} ++ aa#3*{aa#3 <- `aa*`}, GLOBALS ga_I#3*{ga_I#3 <- `ga_I*`} ++ ga#3*{ga#3 <- `ga*`}, MEMS ma_I#3*{ma_I#3 <- `ma_I*`} ++ ma#3*{ma#3 <- `ma*`}, TABLES ta_I#3*{ta_I#3 <- `ta_I*`} ++ ta#3*{ta#3 <- `ta*`}, FUNCS fa_I#3*{fa_I#3 <- `fa_I*`} ++ fa#4*{fa#4 <- `fa*`}, DATAS da#2*{da#2 <- `da*`}, ELEMS ea#2*{ea#2 <- `ea*`}, EXPORTS xi#2*{xi#2 <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- `expr_G*`, globaltype#125 <- `globaltype*`} -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- `memtype*`} @@ -14913,30 +16856,60 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#4*{aa_I#4 <- `aa_I*`} ++ aa#4*{aa#4 <- `aa*`}, GLOBALS ga_I#4*{ga_I#4 <- `ga_I*`} ++ ga#4*{ga#4 <- `ga*`}, MEMS ma_I#4*{ma_I#4 <- `ma_I*`} ++ ma#4*{ma#4 <- `ma*`}, TABLES ta_I#4*{ta_I#4 <- `ta_I*`} ++ ta#4*{ta#4 <- `ta*`}, FUNCS fa_I#4*{fa_I#4 <- `fa_I*`} ++ fa#5*{fa#5 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt#16*{dt#16 <- `dt*`}, TAGS aa_I#5*{aa_I#5 <- `aa_I*`} ++ aa#5*{aa#5 <- `aa*`}, GLOBALS ga_I#5*{ga_I#5 <- `ga_I*`} ++ ga#5*{ga#5 <- `ga*`}, MEMS ma_I#5*{ma_I#5 <- `ma_I*`} ++ ma#5*{ma#5 <- `ma*`}, TABLES ta_I#5*{ta_I#5 <- `ta_I*`} ++ ta#5*{ta#5 <- `ta*`}, FUNCS fa_I#5*{fa_I#5 <- `fa_I*`} ++ fa#6*{fa#6 <- `fa*`}, DATAS da#3*{da#3 <- `da*`}, ELEMS ea#3*{ea#3 <- `ea*`}, EXPORTS xi#3*{xi#3 <- `xi*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = $allocmodule(store, module, var_0, var_1, var_2, var_3)) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_(dataidx : dataidx, data : data) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b#12^n{b#12 <- `b*`}, PASSIVE_datamode)) = [] + def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b#10*{b#10 <- `b*`}, PASSIVE_datamode)) = [] + -- if (n = |`b*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b#13^n{b#13 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b#11*{b#11 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] + -- if (n = |`b*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = $rundata_(dataidx, data)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_(elemidx : elemidx, elem : elem) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#1^n{e#1 <- `e*`}, PASSIVE_elemmode)) = [] + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#1*{e#1 <- `e*`}, PASSIVE_elemmode)) = [] + -- if (n = |`e*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#2^n{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#2*{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] + -- if (n = |`e*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e#3^n{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e#3*{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] + -- if (n = |`e*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = $runelem_(elemidx, elem)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14949,13 +16922,27 @@ def $evalexprs(state : state, expr*) : (state, ref*) def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = $evalexprs(z', expr'#2*{expr'#2 <- `expr'*`}) - -- wf_ref: `%`(ref) -- wf_state: `%`(z') } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprs(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 @@ -14969,6 +16956,21 @@ def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprss(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 def $evalglobals(state : state, globaltype*, expr*) : (state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 @@ -14979,24 +16981,39 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- let{s : store, f : frame} `%;%`_state(s, f) = z' -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}) - -- wf_val: `%`(val) -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $evalglobals(state, var_0, var_1)) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate(store : store, module : module, externaddr*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- `externaddr*`, xt_I#2 <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#7*{global#7 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#7*{table#7 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#7*{elem#7 <- `elem*`}), start#6?{start#6 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`})) = module - -- if (global#8*{global#8 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) - -- if (table#8*{table#8 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`})) = module + -- if (global#7*{global#7 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) + -- if (table#7*{table#7 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) -- if (data#7*{data#7 <- `data*`} = DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`}) - -- if (elem#8*{elem#8 <- `elem*`} = ELEM_elem(reftype#517, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#517 <- `reftype*`}) - -- if (start#7?{start#7 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) + -- if (elem#7*{elem#7 <- `elem*`} = ELEM_elem(reftype#516, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#516 <- `reftype*`}) + -- if (start#6?{start#6 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) -- if (moduleinst_0 = {TYPES $alloctypes(type#6*{type#6 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#9*{externaddr#9 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#10*{externaddr#10 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = $evalglobals(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}) @@ -15005,32 +17022,50 @@ def $instantiate(store : store, module : module, externaddr*) : config -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1])^(i_D#1<|data#8*{data#8 <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem#10*{elem#10 <- `elem*`}[i_E#1])^(i_E#1<|elem#9*{elem#9 <- `elem*`}|){}) + -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem#9*{elem#9 <- `elem*`}[i_E#1])^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){}) -- let{`instr_S?` : instr?} instr_S#1?{instr_S#1 <- `instr_S?`} = CALL_instr(x#7)?{x#7 <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E#2*{instr_E#2 <- `instr_E*`} ++ instr_D#2*{instr_D#2 <- `instr_D*`} ++ lift(instr_S#2?{instr_S#2 <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#3*{xt_I#3 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#9*{global#9 <- `global*`}), `%`_list(mem#8*{mem#8 <- `mem*`}), `%`_list(table#9*{table#9 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#11*{elem#11 <- `elem*`}), start#8?{start#8 <- `start?`}, `%`_list(export#9*{export#9 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#8*{global#8 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#10*{elem#10 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- `expr_G*`, globaltype#130 <- `globaltype*`} -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- `expr_T*`, tabletype#163 <- `tabletype*`} -- (wf_data: `%`(DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)))*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype#519, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#519 <- `reftype*`} + -- (wf_elem: `%`(ELEM_elem(reftype#518, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#518 <- `reftype*`} -- (wf_start: `%`(START_start(x#8)))?{x#8 <- `x?`} -- wf_moduleinst: `%`({TYPES $alloctypes(type#8*{type#8 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#12*{externaddr#12 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#13*{externaddr#13 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data#11*{data#11 <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#12*{elem#12 <- `elem*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- `x?`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = $instantiate(store, module, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke(store : store, funcaddr : funcaddr, val*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val#1*{val#1 <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val#2, t_1#7))*{t_1#7 <- `t_1*`, val#2 <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val#3 : val <: instr)*{val#3 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#8*{t_1#8 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- (Val_ok: `%|-%:%`(s, val#2, t_1#5))*{t_1#5 <- `t_1*`, val#2 <- `val*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $invoke(store, funcaddr, var_0)) + -- wf_config: `%`(ret_val) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -15050,6 +17085,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -15094,11 +17137,23 @@ rec { def $concat_idctxt(idctxt*) : idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'#1*{I'#1 <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) } +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $concat_idctxt(var_0)) + -- wf_idctxt: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec relation Idctxt_ok: `|-%:OK`(idctxt) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -15117,6 +17172,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -15231,6 +17297,19 @@ def $importsd(decl*) : import* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $importsd(var_0)) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 @@ -15244,6 +17323,19 @@ def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tagsd(var_0)) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 @@ -15257,6 +17349,19 @@ def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsd(var_0)) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 @@ -15270,6 +17375,19 @@ def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsd(var_0)) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 @@ -15283,6 +17401,19 @@ def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesd(var_0)) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 @@ -15296,6 +17427,19 @@ def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $funcsd(var_0)) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 @@ -15309,6 +17453,19 @@ def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $datasd(var_0)) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 @@ -15322,6 +17479,19 @@ def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $elemsd(var_0)) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 @@ -15335,6 +17505,19 @@ def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $startsd(var_0)) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 def $exportsd(decl*) : export* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 @@ -15345,6 +17528,19 @@ def $exportsd(decl*) : export* def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#33*{decl'#33 <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) } +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $exportsd(var_0)) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} +} + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $ordered(decl*) : bool ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -15367,8 +17563,6 @@ relation Context_ok: `|-%:OK`(context) -- (Memtype_ok: `%|-%:OK`(C_0, mt))*{mt <- `mt*`} -- (Tabletype_ok: `%|-%:OK`(C_0, tt))*{tt <- `tt*`} -- (Deftype_ok: `%|-%:OK`(C_0, dt_F))*{dt_F <- `dt_F*`} - -- if (|`dt_F*`| = |`t_1*`|) - -- if (|`dt_F*`| = |`t_2*`|) -- (Expand: `%~~%`(dt_F, `FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} @@ -15379,11 +17573,11 @@ relation Context_ok: `|-%:OK`(context) -- wf_context: `%`(C_0) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (n = |`dt*`|) + -- if (m = |`st*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) @@ -15436,25 +17630,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) rule _{s : store, `deftype*` : deftype*, `tagaddr*` : tagaddr*, `globaladdr*` : globaladdr*, `memaddr*` : memaddr*, `tableaddr*` : tableaddr*, `funcaddr*` : funcaddr*, `dataaddr*` : dataaddr*, `elemaddr*` : elemaddr*, `exportinst*` : exportinst*, `tagtype*` : tagtype*, `globaltype*` : globaltype*, `memtype*` : memtype*, `tabletype*` : tabletype*, `deftype_F*` : deftype*, `datatype*` : datatype*, `elemtype*` : elemtype*, `subtype*` : subtype*}: `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} - -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} - -- if (|`globaladdr*`| = |`globaltype*`|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} - -- if (|`deftype_F*`| = |`funcaddr*`|) -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} - -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} - -- if (|`tableaddr*`| = |`tabletype*`|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} - -- if (|`dataaddr*`| = |`datatype*`|) - -- (if (dataaddr < |s.DATAS_store|))*{dataaddr <- `dataaddr*`} -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} - -- if (|`elemaddr*`| = |`elemtype*`|) - -- (if (elemaddr < |s.ELEMS_store|))*{elemaddr <- `elemaddr*`} -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) - -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) @@ -15472,7 +17656,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) rule _{s : store, `val?*` : val?*, moduleinst : moduleinst, C : context, `lct*` : localtype*}: `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -15514,6 +17697,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) + -- if (n = |`t'*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: @@ -15525,6 +17709,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: @@ -15559,16 +17744,13 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -15677,7 +17859,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`zt*`|) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) @@ -15699,10 +17880,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) - -- if (ta < |s.TAGS_store|) -- if ((dt : deftype <: typeuse) = s.TAGS_store[ta].TYPE_taginst) -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (|`t*`| = |`val*`|) -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) @@ -15726,10 +17905,7 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) - -- if (a < |s.STRUCTS_store|) -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (i < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) @@ -15739,8 +17915,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) - -- if (a < |s.ARRAYS_store|) -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) @@ -15749,8 +17923,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule `ref.exn`{a : addr, s : store, i : nat}: `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, (s.EXNS_store[a].FIELDS_exninst[i] : val <: fieldval)) - -- if (i < |s.EXNS_store[a].FIELDS_exninst|) - -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) @@ -15785,19 +17957,12 @@ relation Store_ok: `|-%:OK`(store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: `|-%:OK`(s) - -- if (|`taginst*`| = |`tagtype*`|) -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} - -- if (|`globalinst*`| = |`globaltype*`|) -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} - -- if (|`meminst*`| = |`memtype*`|) -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} - -- if (|`tableinst*`| = |`tabletype*`|) -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} - -- if (|`deftype*`| = |`funcinst*`|) -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} - -- if (|`datainst*`| = |`datatype*`|) -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} - -- if (|`eleminst*`| = |`elemtype*`|) -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} @@ -15884,8 +18049,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`fv'*`|) - -- if (|`fv*`| = |`mut?*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -15897,7 +18060,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?` : mut?, zt : storagetype}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -15915,35 +18077,15 @@ relation Extend_store: `%<=%`(store, store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, s' : store}: `%<=%`(s, s') - -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} - -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} - -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} - -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} - -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} - -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} - -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} - -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} - -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} - -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} - -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} - -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} - -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} - -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} - -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} - -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} - -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} - -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} - -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} - -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -16036,7 +18178,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -16080,6 +18221,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -16105,6 +18254,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -16118,6 +18276,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'#1*{a'#1 <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'#2*{X'#2 <- `X'*`}, Y'#2*{Y'#2 <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -18482,7 +20653,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -18553,7 +20724,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18562,7 +20733,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec diff --git a/spectec/test-middlend/specification.exp/11-sub.il b/spectec/test-middlend/specification.exp/11-sub.il index 93b151b94e..0739095fa7 100644 --- a/spectec/test-middlend/specification.exp/11-sub.il +++ b/spectec/test-middlend/specification.exp/11-sub.il @@ -69,7 +69,9 @@ def $concatn_(syntax X, X**, nat : nat) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2^n{w#2 <- `w*`}] ++ w'#2^n{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2*{w#2 <- `w*`}] ++ w'#2*{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + -- if (n = |`w*`|) + -- (if (n = |`w'*#2`|))*{`w'*#2` <- `w'**`} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -329,19 +331,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -402,23 +425,27 @@ def $utf8(char*) : byte* def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $utf8(var_0)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,10 +639,18 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { @@ -623,70 +658,162 @@ rec { def $free_list(free*) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 def $free_list{free : free, `free'*` : free*}([free] ++ free'#1*{free'#1 <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) } +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_list(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -701,6 +828,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -1149,77 +1285,168 @@ syntax Cnn = | F64 | V128 +def $storagetype_Cnn(Cnn) : storagetype + def $storagetype_Cnn(I32_Cnn) = I32_storagetype + def $storagetype_Cnn(I64_Cnn) = I64_storagetype + def $storagetype_Cnn(F32_Cnn) = F32_storagetype + def $storagetype_Cnn(F64_Cnn) = F64_storagetype + def $storagetype_Cnn(V128_Cnn) = V128_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1290,6 +1517,7 @@ relation wf_limits: `%`(limits) rule limits_case_0{u64 : u64, `u64?` : u64?}: `%`(`[%..%]`_limits(u64, `u64?`)) -- wf_uN: `%%`(64, u64) + -- (wf_uN: `%%`(64, u64))?{u64 <- `u64?`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax tagtype = typeuse @@ -1595,10 +1823,17 @@ def $unpack(storagetype : storagetype) : valtype def $unpack(I32_storagetype) = I32_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I8_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I16_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? @@ -1664,10 +1899,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#1?{null_1#1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#2?{null_1#2 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? @@ -1705,6 +1948,19 @@ def $globalsxt(externtype*) : globaltype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsxt(var_0)) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 @@ -1718,6 +1974,19 @@ def $memsxt(externtype*) : memtype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsxt(var_0)) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 @@ -1731,6 +2000,19 @@ def $tablesxt(externtype*) : tabletype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesxt(var_0)) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 def $funcsxt(externtype*) : deftype* ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 @@ -1757,7 +2039,22 @@ def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($subst_typevar(typevar, var_0, var_1))) + -- wf_typeuse: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1766,11 +2063,25 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#2*{tv'#2 <- `tv'*`}, tu'#2*{tu'#2 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1813,188 +2124,389 @@ def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, $subst_heaptype(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I32_valtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}) = $valtype_numtype($subst_numtype(I32_numtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`})) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I32_valtype, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}) = $valtype_numtype($subst_numtype(I32_numtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I64_valtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}) = $valtype_numtype($subst_numtype(I64_numtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`})) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I64_valtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}) = $valtype_numtype($subst_numtype(I64_numtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F32_valtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}) = $valtype_numtype($subst_numtype(F32_numtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`})) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F32_valtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}) = $valtype_numtype($subst_numtype(F32_numtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F64_valtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}) = $valtype_numtype($subst_numtype(F64_numtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`})) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F64_valtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}) = $valtype_numtype($subst_numtype(F64_numtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(V128_valtype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}) = $valtype_vectype($subst_vectype(V128_vectype, tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`})) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(V128_valtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}) = $valtype_vectype($subst_vectype(V128_vectype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_valtype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}) = $valtype_reftype($subst_reftype(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`})) + def $subst_valtype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_valtype(`null?`, heaptype), tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}) = $valtype_reftype($subst_reftype(REF_reftype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) + def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}) = BOT_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_storagetype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}) = $storagetype_valtype($subst_valtype(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_storagetype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}) = $storagetype_valtype($subst_valtype(BOT_valtype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_storagetype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}) = $storagetype_valtype($subst_valtype(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`})) + def $subst_storagetype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_storagetype(`null?`, heaptype), tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}) = $storagetype_valtype($subst_valtype(REF_valtype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(V128_storagetype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}) = $storagetype_valtype($subst_valtype(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(V128_storagetype, tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}) = $storagetype_valtype($subst_valtype(V128_valtype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F64_storagetype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}) = $storagetype_valtype($subst_valtype(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F64_storagetype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}) = $storagetype_valtype($subst_valtype(F64_valtype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F32_storagetype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}) = $storagetype_valtype($subst_valtype(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F32_storagetype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}) = $storagetype_valtype($subst_valtype(F32_valtype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I64_storagetype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}) = $storagetype_valtype($subst_valtype(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I64_storagetype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}) = $storagetype_valtype($subst_valtype(I64_valtype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I32_storagetype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}) = $storagetype_valtype($subst_valtype(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I32_storagetype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}) = $storagetype_valtype($subst_valtype(I32_valtype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I8_storagetype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}) = $storagetype_packtype($subst_packtype(I8_packtype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I8_storagetype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}) = $storagetype_packtype($subst_packtype(I8_packtype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I16_storagetype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}) = $storagetype_packtype($subst_packtype(I16_packtype, tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`})) + def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I16_storagetype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}) = $storagetype_packtype($subst_packtype(I16_packtype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, $subst_storagetype(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}))) + def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`})*{ft#2 <- `ft*`}))) + def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}))) + def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`})*{t_1#2 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`})*{t_2#2 <- `t_2*`}))) + def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, $subst_typeuse(tu'#4, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`})*{tu'#4 <- `tu'*`}, $subst_comptype(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}))) + def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#5*{tu'#5 <- `tu'*`}) = !($minus_recs(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`})) + def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#4*{tu'#4 <- `tu'*`}) = !($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) + def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_typeuse(typeuse, var_0, var_1)) + -- wf_typeuse: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_heaptype(heaptype, var_0, var_1)) + -- wf_heaptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_reftype(reftype, var_0, var_1)) + -- wf_reftype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_valtype(valtype, var_0, var_1)) + -- wf_valtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_storagetype(storagetype, var_0, var_1)) + -- wf_storagetype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_fieldtype(fieldtype, var_0, var_1)) + -- wf_fieldtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_comptype(comptype, var_0, var_1)) + -- wf_comptype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_subtype(subtype, var_0, var_1)) + -- wf_subtype: `%`(ret_val) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}) = at + def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}) = at ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, $subst_valtype(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}))) + def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut#2?{mut#2 <- `mut?`}, t), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_globaltype(globaltype, var_0, var_1)) + -- wf_globaltype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#72*{tv#72 <- `tv*`}, tu#72*{tu#72 <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}) = `%%PAGE`_memtype(at, lim) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}))) + def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_tabletype(tabletype, var_0, var_1)) + -- wf_tabletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}))) + def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}))) + def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}))) + def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}))) + def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}))) + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_externtype(externtype, var_0, var_1)) + -- wf_externtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#85*{tv#85 <- `tv*`}, tu#85*{tu#85 <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`})*{xt_1#2 <- `xt_1*`}, $subst_externtype(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`})*{xt_2#2 <- `xt_2*`})) + def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_moduletype(moduletype, var_0, var_1)) + -- wf_moduletype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu#88^n{tu#88 <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $free_moduletype(moduletype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = | mk_num__0(Inn : Inn, var_x : iN) @@ -2791,7 +3536,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4505,7 +5258,6 @@ relation wf_instr: `%`(instr) `%`(VEXTRACT_LANE_instr(shape, `sx?`, laneidx)) -- wf_shape: `%`(shape) -- wf_uN: `%%`(8, laneidx) - -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 @@ -4578,38 +5330,67 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) - -- wf_instr: `%`(CONST_instr(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) - -- wf_instr: `%`(CONST_instr(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) - -- wf_instr: `%`(CONST_instr(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_consttype(consttype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype(blocktype : blocktype) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) + def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype#504?{valtype#504 <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $free_blocktype(blocktype)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4621,6 +5402,15 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { @@ -4632,7 +5422,6 @@ def $shift_labelidxs(labelidx*) : labelidx* def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}) = [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4642,15 +5431,12 @@ rec { def $free_instr(instr : instr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) + def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype#505*{valtype#505 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 @@ -4679,7 +5465,6 @@ def $free_instr(instr : instr) : free def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 @@ -4690,7 +5475,6 @@ def $free_instr(instr : instr) : free def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 @@ -4753,13 +5537,10 @@ def $free_instr(instr : instr) : free def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 @@ -4768,10 +5549,8 @@ def $free_instr(instr : instr) : free def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 @@ -4796,7 +5575,6 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 @@ -4807,10 +5585,8 @@ def $free_instr(instr : instr) : free def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 @@ -4869,11 +5645,42 @@ def $free_block(instr*) : free -- let{free : free} free = $free_list($free_instr(instr#5)*{instr#5 <- `instr*`}) } +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = $free_instr(instr)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $free_block(var_0)) + -- wf_free: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr(expr : expr) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_expr{`instr*` : instr*}(instr#6*{instr#6 <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = $free_expr(expr)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = | ACTIVE(tableidx : tableidx, expr : expr) @@ -5064,85 +5871,216 @@ def $free_type(type : type) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free}: + `%%`(type, ret_val) + -- if (ret_val = $free_type(type)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag(tag : tag) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = $free_tag(tag)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global(global : global) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = $free_global(global)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table(table : table) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = $free_table(table)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local(local : local) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = $free_local(local)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func(func : func) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = $free_func(func)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(datamode : datamode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = $free_datamode(datamode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data(data : data) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode)) = $free_datamode(datamode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_data_is_wf: `%%`(data : data, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_data_is_wf_0{data : data, ret_val : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = $free_data(data)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(elemmode : elemmode) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = $free_elemmode(elemmode)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem(elem : elem) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_elem_is_wf_0{elem : elem, ret_val : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = $free_elem(elem)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import(import : import) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = $free_import(import)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module(module : module) : free ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = $free_module(module)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $funcidx_module(module : module) : funcidx* ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec @@ -5228,6 +6166,21 @@ def $with_locals(context : context, localidx*, localtype*) : context? ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($with_locals(context, var_0, var_1))) + -- wf_context: `%`(ret_val) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 def $clos_deftypes(deftype*) : deftype* ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 @@ -5243,6 +6196,16 @@ def $clos_valtype(context : context, valtype : valtype) : valtype def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, $typeuse_deftype(dt)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $clos_valtype(context, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_deftype(context : context, deftype : deftype) : deftype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -5261,12 +6224,32 @@ def $clos_externtype(context : context, externtype : externtype) : externtype def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, $typeuse_deftype(dt)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = $clos_externtype(context, externtype)) + -- wf_externtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype(context : context, moduletype : moduletype) : moduletype ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}) -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = $clos_deftypes(C.TYPES_context) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = $clos_moduletype(context, moduletype)) + -- wf_moduletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5312,6 +6295,7 @@ relation Expand: `%~~%`(deftype, comptype) rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: `%~~%`(deftype, comptype) -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`($unrolldt(deftype)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -5337,6 +6321,16 @@ def $unrollht_(context : context, heaptype : heaptype) : subtype ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = $unrollht_(context, heaptype)) + -- wf_subtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5401,7 +6395,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5409,7 +6402,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) -- wf_context: `%`(C) -- wf_subtype: `%`(st) @@ -5486,12 +6478,11 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- if (|`comptype'*`| = |`typeuse*`|) - -- if (|`comptype'*`| = |`typeuse'**`|) -- (if ($unrollht_(C, $heaptype_typeuse(typeuse)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrollht_(C, $heaptype_typeuse(typeuse))))*{typeuse <- `typeuse*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} @@ -5521,13 +6512,13 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) -- if (i < n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- if (n = |`subtype*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} -- wf_context: `%`(C) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) @@ -5562,9 +6553,9 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: `%|-%<:%`(C, deftype_1, deftype_2) -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |typeuse*{typeuse <- `typeuse*`}|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[i]), $heaptype_deftype(deftype_2)) -- wf_context: `%`(C) + -- wf_subtype: `%`($unrolldt(deftype_1)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5647,7 +6638,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5656,7 +6646,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0])) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5665,7 +6654,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5675,7 +6663,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5685,7 +6672,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5695,8 +6681,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: `%|-%<:%`(C, REC_heaptype(i), $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[j])) - -- if (j < |typeuse*{typeuse <- `typeuse*`}|) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5805,7 +6789,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`t_1*`| = |`t_2*`|) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} @@ -5863,8 +6846,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`lct*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- `lct*`} @@ -5882,7 +6863,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) @@ -5906,13 +6886,11 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- if (|`comptype'*`| = |`yy**`|) - -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} -- (if ($unrolldt(C.TYPES_context[$proj_uN_0(x).0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`($unrolldt(C.TYPES_context[$proj_uN_0(x).0])))*{x <- `x*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} @@ -6036,11 +7014,10 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) - -- if (|`t*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -6169,7 +7146,6 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) @@ -6181,10 +7157,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) @@ -6193,10 +7166,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) @@ -6205,7 +7175,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) @@ -6213,7 +7182,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) @@ -6222,35 +7190,38 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F32_valtype) = ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F64_valtype) = ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%DEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6352,7 +7323,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6363,7 +7333,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, `t*` : valtype*}: `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) @@ -6372,9 +7341,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]))*{l <- `l*`} - -- if ($proj_uN_0(l').0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l').0]) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6384,7 +7351,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) @@ -6394,7 +7360,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -6403,7 +7368,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6417,7 +7381,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6425,13 +7388,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) @@ -6441,7 +7404,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) @@ -6451,10 +7413,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) @@ -6476,7 +7436,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6491,7 +7450,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6506,10 +7464,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6526,8 +7482,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6568,9 +7522,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule `ref.func`{C : context, x : idx, dt : deftype}: `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) - -- if (|C.REFS_context| > 0) -- if (x <- C.REFS_context) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) @@ -6636,7 +7588,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) @@ -6646,10 +7597,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6657,9 +7608,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6671,9 +7620,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) @@ -6684,7 +7631,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) @@ -6694,10 +7640,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6705,7 +7651,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -6715,9 +7660,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) @@ -6727,12 +7670,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6740,7 +7682,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6751,7 +7692,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule `array.set`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) @@ -6768,7 +7708,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule `array.fill`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) @@ -6778,9 +7717,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) @@ -6792,9 +7729,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), zt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) @@ -6804,12 +7739,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6833,7 +7767,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule `local.get`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) @@ -6843,7 +7776,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule `local.set`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) @@ -6853,7 +7785,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule `local.tee`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) @@ -6863,7 +7794,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -6873,7 +7803,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule `global.set`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) @@ -6883,7 +7812,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GET`_instr(x)) @@ -6893,7 +7821,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -6903,7 +7830,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) @@ -6913,7 +7839,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GROW`_instr(x)) @@ -6923,7 +7848,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) @@ -6933,9 +7857,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6947,9 +7869,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6961,7 +7881,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule `elem.drop`{C : context, x : idx, rt : reftype}: `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) @@ -6971,7 +7890,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) @@ -6981,7 +7899,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) @@ -6991,7 +7908,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) @@ -7001,9 +7917,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) @@ -7014,9 +7928,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) @@ -7026,7 +7938,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule `data.drop`{C : context, x : idx}: `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) @@ -7035,7 +7946,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -7046,7 +7956,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -7057,7 +7966,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -7068,7 +7976,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -7079,7 +7986,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -7090,7 +7996,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) -- wf_context: `%`(C) @@ -7101,7 +8006,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -7112,7 +8016,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -7123,7 +8026,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -7135,7 +8037,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -7146,7 +8047,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -7293,6 +8193,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -7308,6 +8209,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) @@ -7316,6 +8218,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) @@ -7366,15 +8269,12 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -7418,9 +8318,9 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7499,7 +8399,6 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule `global.get`{C : context, x : idx, t : valtype}: `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -7508,9 +8407,7 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, Inn : Inn, binop : binop_}: `%|-%CONST`(C, BINOP_instr($numtype_addrtype(Inn), binop)) - -- if (|[I32_Inn I64_Inn]| > 0) -- if (Inn <- [I32_Inn I64_Inn]) - -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr($numtype_addrtype(Inn), binop)) @@ -7557,6 +8454,7 @@ relation Tag_ok: `%|-%:%`(context, tag, tagtype) `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`($clos_tagtype(C, tagtype)) -- wf_tag: `%`(TAG_tag(tagtype)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7615,9 +8513,7 @@ relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[$proj_uN_0(x).0]) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`lct*`| = |`local*`|) -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- wf_context: `%`(C) @@ -7636,7 +8532,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) @@ -7671,7 +8566,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) @@ -7696,7 +8590,6 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) @@ -7709,6 +8602,7 @@ relation Import_ok: `%|-%:%`(context, import, externtype) `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`($clos_externtype(C, xt)) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7716,7 +8610,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) @@ -7725,7 +8618,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) @@ -7734,7 +8626,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) @@ -7743,7 +8634,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) @@ -7752,7 +8642,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) @@ -7829,7 +8718,6 @@ relation wf_nonfuncs: `%`(nonfuncs) def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#3*{export#3 <- `export*`}))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -7837,24 +8725,15 @@ relation Module_ok: `|-%:%`(module, moduletype) rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) - -- if (|`import*`| = |`xt_I*`|) -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} - -- if (|`jt*`| = |`tag*`|) -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- if (|`mem*`| = |`mt*`|) -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} - -- if (|`table*`| = |`tt*`|) -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} - -- if (|`dt*`| = |`func*`|) -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} - -- if (|`data*`| = |`ok*`|) -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} - -- if (|`elem*`| = |`rt*`|) -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} - -- if (|`export*`| = |`nm*`|) - -- if (|`export*`| = |`xt_E*`|) -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7868,6 +8747,12 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`($clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + -- (wf_uN: `%%`(32, iter))*{iter <- $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))} + -- (wf_typeuse: `%`(iter))*{iter <- $tagsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_globaltype: `%`(iter))*{iter <- $globalsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_memtype: `%`(iter))*{iter <- $memsxt(xt_I*{xt_I <- `xt_I*`})} + -- (wf_tabletype: `%`(iter))*{iter <- $tablesxt(xt_I*{xt_I <- `xt_I*`})} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7921,81 +8806,272 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $signed_(N : N, nat : nat) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -8037,22 +9113,24 @@ def $sx(storagetype : storagetype) : sx?? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F32_lanetype) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F64_lanetype) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -8081,7 +9159,6 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN @@ -8101,28 +9178,23 @@ def $ipopcnt_(N : N, iN : iN) : iN def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ M)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -8130,7 +9202,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -8138,7 +9209,6 @@ def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? -- if ((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? @@ -8146,13 +9216,11 @@ def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) -- if ((j_1 = $signed_(N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8180,19 +9248,15 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8243,130 +9307,291 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsqrt_(N : N, fN : fN) : fN* +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fceil_(N : N, fN : fN) : fN* +def $fsqrt_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ffloor_(N : N, fN : fN) : fN* +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $ftrunc_(N : N, fN : fN) : fN* +def $fceil_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fnearest_(N : N, fN : fN) : fN* +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fadd_(N : N, fN : fN, fN : fN) : fN* +def $ffloor_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fsub_(N : N, fN : fN, fN : fN) : fN* +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmul_(N : N, fN : fN, fN : fN) : fN* +def $ftrunc_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fdiv_(N : N, fN : fN, fN : fN) : fN* +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmin_(N : N, fN : fN, fN : fN) : fN* +def $fnearest_(N : N, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fmax_(N : N, fN : fN, fN : fN) : fN* +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmin_(N : N, fN : fN, fN : fN) : fN* +def $fadd_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fpmax_(N : N, fN : fN, fN : fN) : fN* +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +def $fsub_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +def $fmul_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $feq_(N : N, fN : fN, fN : fN) : u32 +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fne_(N : N, fN : fN, fN : fN) : u32 +def $fdiv_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $flt_(N : N, fN : fN, fN : fN) : u32 +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fgt_(N : N, fN : fN, fN : fN) : u32 +def $fmin_(N : N, fN : fN, fN : fN) : fN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fle_(N : N, fN : fN, fN : fN) : u32 +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmin_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fpmax_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fcopysign_(N : N, fN : fN, fN : fN) : fN* + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $feq_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fne_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $flt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fgt_(N : N, fN : fN, fN : fN) : u32 + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $fle_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fge_(N : N, fN : fN, fN : fN) : u32 @@ -8374,9 +9599,31 @@ def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -8395,38 +9642,77 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I32_numtype), mk_lane__0_lane_(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I64_numtype), mk_lane__0_lane_(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F32_numtype), mk_lane__0_lane_(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F64_numtype), mk_lane__0_lane_(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I8_packtype), mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I16_packtype), mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8442,10 +9728,18 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I8_packtype), mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I16_packtype), mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -8459,10 +9753,17 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I8_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I16_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8478,196 +9779,165 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I8_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I16_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{M : nat, i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $unop_{M : nat, i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#1)))*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#1)*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#3)))*{iter_0#3 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#3)*{iter_0#3 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#6)*{iter_0#6 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#5)))*{iter_0#5 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#7)))*{iter_0#7 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#5)*{iter_0#5 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#10)*{iter_0#10 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#9)))*{iter_0#9 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#6)*{iter_0#6 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#11)))*{iter_0#11 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#7)*{iter_0#7 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#14)*{iter_0#14 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#13)))*{iter_0#13 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#16)*{iter_0#16 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#15)))*{iter_0#15 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#9)*{iter_0#9 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#18)*{iter_0#18 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#17)))*{iter_0#17 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#10)*{iter_0#10 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#19)))*{iter_0#19 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#11)*{iter_0#11 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#22)*{iter_0#22 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#21)))*{iter_0#21 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#23)))*{iter_0#23 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} + def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#13)*{iter_0#13 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#26)*{iter_0#26 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#25)))*{iter_0#25 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} + def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#14)*{iter_0#14 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#27)))*{iter_0#27 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $unop_(numtype, unop_, num_)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#30)*{iter_0#30 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#15)*{iter_0#15 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#32)*{iter_0#32 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#16)*{iter_0#16 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#17)*{iter_0#17 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} + def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#18)*{iter_0#18 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#38)*{iter_0#38 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#37)))*{iter_0#37 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#19)*{iter_0#19 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#40)*{iter_0#40 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#39)))*{iter_0#39 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#21)*{iter_0#21 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#41)))*{iter_0#41 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#22)*{iter_0#22 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#43)))*{iter_0#43 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#23)*{iter_0#23 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#45)))*{iter_0#45 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#47)))*{iter_0#47 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#25)*{iter_0#25 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#50)*{iter_0#50 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49)))*{iter_0#49 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#26)*{iter_0#26 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#52)*{iter_0#52 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51)))*{iter_0#51 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#27)*{iter_0#27 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#54)*{iter_0#54 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#53)))*{iter_0#53 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#56)*{iter_0#56 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#55)))*{iter_0#55 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#29)*{iter_0#29 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#58)*{iter_0#58 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#57)))*{iter_0#57 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#30)*{iter_0#30 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#60)*{iter_0#60 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#59)))*{iter_0#59 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#31)*{iter_0#31 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#62)*{iter_0#62 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61)))*{iter_0#61 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#32)*{iter_0#32 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#64)*{iter_0#64 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63)))*{iter_0#63 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = $binop_(numtype, binop_, num_, num__0)) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -8731,324 +10001,500 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#66)*{iter_0#66 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#65)))*{iter_0#65 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#33)*{iter_0#33 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#68)*{iter_0#68 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#67)))*{iter_0#67 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#70)*{iter_0#70 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#69)))*{iter_0#69 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#35)*{iter_0#35 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#72)*{iter_0#72 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#71)))*{iter_0#71 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#74)*{iter_0#74 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#73)))*{iter_0#73 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#37)*{iter_0#37 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#76)*{iter_0#76 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#75)))*{iter_0#75 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#38)*{iter_0#38 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#78)*{iter_0#78 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#77)))*{iter_0#77 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#39)*{iter_0#39 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#80)*{iter_0#80 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#79)))*{iter_0#79 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#40)*{iter_0#40 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#82)*{iter_0#82 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#81)))*{iter_0#81 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#41)*{iter_0#41 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#84)*{iter_0#84 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#83)))*{iter_0#83 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#86)*{iter_0#86 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#85)))*{iter_0#85 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#43)*{iter_0#43 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#88)*{iter_0#88 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#87)))*{iter_0#87 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#90)*{iter_0#90 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#89)))*{iter_0#89 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#45)*{iter_0#45 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#92)*{iter_0#92 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#91)))*{iter_0#91 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#94)*{iter_0#94 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#93)))*{iter_0#93 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#47)*{iter_0#47 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#96)*{iter_0#96 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#95)))*{iter_0#95 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))] -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))] -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))] -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))] -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))] -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))] -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))] -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cvtop__{f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))] -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $cvtop__(numtype_1, numtype_2, cvtop__, num_)) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx))) = ?() + def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`}))) = zero#3442?{zero#3442 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`}))) = zero#3442?{zero#3442 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`}))) = zero#3444?{zero#3444 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`}))) = zero#3444?{zero#3444 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`}))) = zero#3446?{zero#3446 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`}))) = zero#3446?{zero#3446 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`}))) = zero#3448?{zero#3448 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`}))) = zero#3448?{zero#3448 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`}))) = zero#3450?{zero#3450 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`}))) = zero#3450?{zero#3450 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`}))) = zero#3452?{zero#3452 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`}))) = zero#3452?{zero#3452 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`}))) = zero#3454?{zero#3454 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`}))) = zero#3454?{zero#3454 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`}))) = zero#3456?{zero#3456 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`}))) = zero#3456?{zero#3456 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`}))) = zero#3458?{zero#3458 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`}))) = zero#3458?{zero#3458 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`}))) = zero#3460?{zero#3460 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`}))) = zero#3460?{zero#3460 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`}))) = zero#3462?{zero#3462 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`}))) = zero#3462?{zero#3462 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`}))) = zero#3464?{zero#3464 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`}))) = zero#3464?{zero#3464 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`}))) = zero#3466?{zero#3466 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`}))) = zero#3466?{zero#3466 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`}))) = zero#3468?{zero#3468 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`}))) = zero#3468?{zero#3468 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`}))) = zero#3470?{zero#3470 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`}))) = zero#3470?{zero#3470 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`}))) = zero#3472?{zero#3472 <- `zero?`} + def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`}))) = zero#3472?{zero#3472 <- `zero?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + def $zeroop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + def $zeroop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx))) = half#3046?{half#3046 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx))) = half#3046?{half#3046 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx))) = half#3048?{half#3048 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx))) = half#3048?{half#3048 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx))) = half#3050?{half#3050 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx))) = half#3050?{half#3050 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx))) = half#3052?{half#3052 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx))) = half#3052?{half#3052 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx))) = half#3054?{half#3054 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx))) = half#3054?{half#3054 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx))) = half#3056?{half#3056 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx))) = half#3056?{half#3056 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx))) = half#3058?{half#3058 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx))) = half#3058?{half#3058 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx))) = half#3060?{half#3060 <- `half?`} + def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx))) = half#3060?{half#3060 <- `half?`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`}))) = ?() + def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`}))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + def $halfop{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + def $halfop{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $half(half : half, nat : nat, nat : nat) : nat @@ -9061,366 +10507,332 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#1*{c#1 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if ($signed_(N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#5)*{c#5 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#4)*{c#4 <- `c*`})] -- let{`c_1*` : lane_*} c_1#1*{c_1#1 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c*` : iN*} c#3*{c#3 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#2)))*{c_1#2 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#4)))*{c#4 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#8)*{c#8 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#6)*{c#6 <- `c*`})] -- let{`c_1*` : lane_*} c_1#3*{c_1#3 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#6*{c#6 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} + -- let{`c*` : iN*} c#5*{c#5 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#7)))*{c#7 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#11)*{c#11 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#8)*{c#8 <- `c*`})] -- let{`c_1*` : lane_*} c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} + -- let{`c*` : iN*} c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#10)))*{c#10 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#14)*{c#14 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#10)*{c#10 <- `c*`})] -- let{`c_1*` : lane_*} c_1#7*{c_1#7 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#12*{c#12 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} + -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#13)))*{c#13 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#16*{c#16 <- `c*#2`})*{`c*#2` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#12*{c#12 <- `c*#2`})*{`c*#2` <- `c**`} -- let{`c_1*` : lane_*} c_1#9*{c_1#9 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#15*{c#15 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#97))*{iter_0#97 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) + -- let{`c**` : lane_**} c#11*{c#11 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49))*{iter_0#49 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#98))))*{iter_0#98 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#50))))*{iter_0#50 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#18*{c#18 <- `c*#4`})*{`c*#4` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#14*{c#14 <- `c*#4`})*{`c*#4` <- `c**`} -- let{`c_1*` : lane_*} c_1#12*{c_1#12 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#17*{c#17 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#99))*{iter_0#99 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) + -- let{`c**` : lane_**} c#13*{c#13 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51))*{iter_0#51 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#100))))*{iter_0#100 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#52))))*{iter_0#52 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#21)*{c#21 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#16)*{c#16 <- `c*`})] -- let{`c_1*` : lane_*} c_1#15*{c_1#15 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#1*{c_2#1 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} + -- let{`c*` : iN*} c#15*{c#15 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#20)))*{c#20 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#24)*{c#24 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#18)*{c#18 <- `c*`})] -- let{`c_1*` : lane_*} c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#3*{c_2#3 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#22*{c#22 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} + -- let{`c*` : iN*} c#17*{c#17 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#23)))*{c#23 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#27)*{c#27 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#20)*{c#20 <- `c*`})] -- let{`c_1*` : lane_*} c_1#19*{c_1#19 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} + -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#26)))*{c#26 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#22)*{c#22 <- `c*`})] -- let{`c_1*` : lane_*} c_1#21*{c_1#21 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#7*{c_2#7 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#28*{c#28 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} + -- let{`c*` : iN*} c#21*{c#21 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#29)))*{c#29 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#33)*{c#33 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#24)*{c#24 <- `c*`})] -- let{`c_1*` : lane_*} c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#9*{c_2#9 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#31*{c#31 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} + -- let{`c*` : iN*} c#23*{c#23 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#32)))*{c#32 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#36)*{c#36 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#26)*{c#26 <- `c*`})] -- let{`c_1*` : lane_*} c_1#25*{c_1#25 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#34*{c#34 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} + -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#35)))*{c#35 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#39)*{c#39 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#28)*{c#28 <- `c*`})] -- let{`c_1*` : lane_*} c_1#27*{c_1#27 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#13*{c_2#13 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#37*{c#37 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} + -- let{`c*` : iN*} c#27*{c#27 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#38)))*{c#38 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#42)*{c#42 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] -- let{`c_1*` : lane_*} c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#15*{c_2#15 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#40*{c#40 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} + -- let{`c*` : iN*} c#29*{c#29 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#41)))*{c#41 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#6`})*{`c*#6` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#32*{c#32 <- `c*#6`})*{`c*#6` <- `c**`} -- let{`c_1*` : lane_*} c_1#31*{c_1#31 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#43*{c#43 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#101)*{iter_0#101 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) + -- let{`c**` : lane_**} c#31*{c#31 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#53)*{iter_0#53 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#102)))*{iter_0#102 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#54)))*{iter_0#54 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#8`})*{`c*#8` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#34*{c#34 <- `c*#8`})*{`c*#8` <- `c**`} -- let{`c_1*` : lane_*} c_1#34*{c_1#34 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#45*{c#45 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#103)*{iter_0#103 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) + -- let{`c**` : lane_**} c#33*{c#33 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#55)*{iter_0#55 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#104)))*{iter_0#104 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#56)))*{iter_0#56 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#10`})*{`c*#10` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#36*{c#36 <- `c*#10`})*{`c*#10` <- `c**`} -- let{`c_1*` : lane_*} c_1#37*{c_1#37 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#47*{c#47 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#105)*{iter_0#105 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) + -- let{`c**` : lane_**} c#35*{c#35 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#57)*{iter_0#57 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#106)))*{iter_0#106 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#58)))*{iter_0#58 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#12`})*{`c*#12` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#38*{c#38 <- `c*#12`})*{`c*#12` <- `c**`} -- let{`c_1*` : lane_*} c_1#40*{c_1#40 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#49*{c#49 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#107)*{iter_0#107 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) + -- let{`c**` : lane_**} c#37*{c#37 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#59)*{iter_0#59 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#108)))*{iter_0#108 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#60)))*{iter_0#60 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#14`})*{`c*#14` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#40*{c#40 <- `c*#14`})*{`c*#14` <- `c**`} -- let{`c_1*` : lane_*} c_1#43*{c_1#43 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#51*{c#51 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#109))*{iter_0#109 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) + -- let{`c**` : lane_**} c#39*{c#39 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61))*{iter_0#61 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#110))))*{iter_0#110 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#62))))*{iter_0#62 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#16`})*{`c*#16` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#42*{c#42 <- `c*#16`})*{`c*#16` <- `c**`} -- let{`c_1*` : lane_*} c_1#46*{c_1#46 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#53*{c#53 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#111))*{iter_0#111 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) + -- let{`c**` : lane_**} c#41*{c#41 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63))*{iter_0#63 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#112))))*{iter_0#112 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#64))))*{iter_0#64 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#56*{c#56 <- `c*#18`})*{`c*#18` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#18`})*{`c*#18` <- `c**`} -- let{`c_1*` : lane_*} c_1#49*{c_1#49 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#1*{c_3#1 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#55*{c#55 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#113)*{iter_0#113 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) + -- let{`c**` : lane_**} c#43*{c#43 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#65)*{iter_0#65 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#114)))*{iter_0#114 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#66)))*{iter_0#66 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#58*{c#58 <- `c*#20`})*{`c*#20` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#20`})*{`c*#20` <- `c**`} -- let{`c_1*` : lane_*} c_1#52*{c_1#52 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#4*{c_3#4 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#57*{c#57 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#115)*{iter_0#115 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) + -- let{`c**` : lane_**} c#45*{c#45 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#67)*{iter_0#67 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#116)))*{iter_0#116 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#68)))*{iter_0#68 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#60*{c#60 <- `c*#22`})*{`c*#22` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#22`})*{`c*#22` <- `c**`} -- let{`c_1*` : lane_*} c_1#55*{c_1#55 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#7*{c_3#7 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#59*{c#59 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#117)*{iter_0#117 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) + -- let{`c**` : lane_**} c#47*{c#47 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#69)*{iter_0#69 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#118)))*{iter_0#118 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#70)))*{iter_0#70 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#62*{c#62 <- `c*#24`})*{`c*#24` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#24`})*{`c*#24` <- `c**`} -- let{`c_1*` : lane_*} c_1#58*{c_1#58 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#10*{c_3#10 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#61*{c#61 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#119)*{iter_0#119 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) + -- let{`c**` : lane_**} c#49*{c#49 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#71)*{iter_0#71 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#120)))*{iter_0#120 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#72)))*{iter_0#72 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#64*{c#64 <- `c*#26`})*{`c*#26` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#26`})*{`c*#26` <- `c**`} -- let{`c_1*` : lane_*} c_1#61*{c_1#61 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#13*{c_3#13 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#63*{c#63 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#121))*{iter_0#121 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) + -- let{`c**` : lane_**} c#51*{c#51 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#73))*{iter_0#73 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#122))))*{iter_0#122 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#74))))*{iter_0#74 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#66*{c#66 <- `c*#28`})*{`c*#28` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#28`})*{`c*#28` <- `c**`} -- let{`c_1*` : lane_*} c_1#64*{c_1#64 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#16*{c_3#16 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#65*{c#65 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#123))*{iter_0#123 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) + -- let{`c**` : lane_**} c#53*{c#53 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#75))*{iter_0#75 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#124))))*{iter_0#124 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#76))))*{iter_0#76 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#69)*{c#69 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#56)*{c#56 <- `c*`}) -- let{`c_1*` : lane_*} c_1#67*{c_1#67 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} + -- let{`c*` : iN*} c#55*{c#55 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#68)))*{c#68 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- `c_1*`, c_2#55 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#72)*{c#72 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#58)*{c#58 <- `c*`}) -- let{`c_1*` : lane_*} c_1#70*{c_1#70 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#70*{c#70 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} + -- let{`c*` : iN*} c#57*{c#57 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#71)))*{c#71 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- `c_1*`, c_2#58 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#75)*{c#75 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#60)*{c#60 <- `c*`}) -- let{`c_1*` : lane_*} c_1#73*{c_1#73 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} + -- let{`c*` : iN*} c#59*{c#59 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#74)))*{c#74 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- `c_1*`, c_2#61 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#78)*{c#78 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#62)*{c#62 <- `c*`}) -- let{`c_1*` : lane_*} c_1#76*{c_1#76 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#76*{c#76 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} + -- let{`c*` : iN*} c#61*{c#61 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#77)))*{c#77 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- `c_1*`, c_2#64 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#81)*{c#81 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#64)*{c#64 <- `c*`}) -- let{`c_1*` : lane_*} c_1#79*{c_1#79 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} + -- let{`c*` : iN*} c#63*{c#63 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#80)))*{c#80 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- `c_1*`, c_2#67 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#84)*{c#84 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#66)*{c#66 <- `c*`}) -- let{`c_1*` : lane_*} c_1#82*{c_1#82 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#82*{c#82 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} + -- let{`c*` : iN*} c#65*{c#65 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#83)))*{c#83 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- `c_1*`, c_2#70 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#87)*{c#87 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#68)*{c#68 <- `c*`}) -- let{`c_1*` : lane_*} c_1#85*{c_1#85 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} + -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#86)))*{c#86 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- `c_1*`, c_2#73 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#70)*{c#70 <- `c*`}) -- let{`c_1*` : lane_*} c_1#88*{c_1#88 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#88*{c#88 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} + -- let{`c*` : iN*} c#69*{c#69 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#89)))*{c#89 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- `c_1*`, c_2#76 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#93).0)))*{c#93 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#72).0)))*{c#72 <- `c*`}) -- let{`c_1*` : lane_*} c_1#91*{c_1#91 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} + -- let{`c*` : iN*} c#71*{c#71 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} -- if ($isize(Inn) = $fsize(F32_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#92).0)))))*{c#92 <- `c*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- `c_1*`, c_2#79 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#96).0)))*{c#96 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#74).0)))*{c#74 <- `c*`}) -- let{`c_1*` : lane_*} c_1#94*{c_1#94 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#94*{c#94 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} + -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} -- if ($isize(Inn) = $fsize(F64_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#95).0)))))*{c#95 <- `c*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- `c_1*`, c_2#82 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#99)*{c#99 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#76)*{c#76 <- `c*`}) -- let{`c_1*` : lane_*} c_1#97*{c_1#97 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} + -- let{`c*` : iN*} c#75*{c#75 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#98)))*{c#98 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#102)*{c#102 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#78)*{c#78 <- `c*`}) -- let{`c_1*` : lane_*} c_1#99*{c_1#99 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#100*{c#100 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} + -- let{`c*` : iN*} c#77*{c#77 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#101)))*{c#101 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#105)*{c#105 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#80)*{c#80 <- `c*`}) -- let{`c_1*` : lane_*} c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#103*{c#103 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} + -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#104)))*{c#104 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#108)*{c#108 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#82)*{c#82 <- `c*`}) -- let{`c_1*` : lane_*} c_1#103*{c_1#103 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#106*{c#106 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} + -- let{`c*` : iN*} c#81*{c#81 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#107)))*{c#107 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#111)*{c#111 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#84)*{c#84 <- `c*`}) -- let{`c_1*` : lane_*} c_1#105*{c_1#105 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#109*{c#109 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} + -- let{`c*` : iN*} c#83*{c#83 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#110)))*{c#110 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#114)*{c#114 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#86)*{c#86 <- `c*`}) -- let{`c_1*` : lane_*} c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#112*{c#112 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} + -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#113)))*{c#113 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#117)*{c#117 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#88)*{c#88 <- `c*`}) -- let{`c_1*` : lane_*} c_1#109*{c_1#109 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#115*{c#115 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} + -- let{`c*` : iN*} c#87*{c#87 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#116)))*{c#116 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#120)*{c#120 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) -- let{`c_1*` : lane_*} c_1#111*{c_1#111 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#118*{c#118 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} + -- let{`c*` : iN*} c#89*{c#89 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#119)))*{c#119 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 @@ -9428,7 +10840,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9436,7 +10847,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9444,7 +10854,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9452,7 +10861,6 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) -- let{`c_1*` : lane_*} c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9460,59 +10868,55 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#123)*{c#123 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#92)*{c#92 <- `c*`}) -- let{`c_1*` : lane_*} c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#121*{c#121 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} + -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#122)))*{c#122 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#126)*{c#126 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#94)*{c#94 <- `c*`}) -- let{`c_1*` : lane_*} c_1#127*{c_1#127 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#85*{c_2#85 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#124*{c#124 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} + -- let{`c*` : iN*} c#93*{c#93 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#125)))*{c#125 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#129)*{c#129 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#96)*{c#96 <- `c*`}) -- let{`c_1*` : lane_*} c_1#129*{c_1#129 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#87*{c_2#87 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#127*{c#127 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} + -- let{`c*` : iN*} c#95*{c#95 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#128)))*{c#128 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#132)*{c#132 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#98)*{c#98 <- `c*`}) -- let{`c_1*` : lane_*} c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#130*{c#130 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} + -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#131)))*{c#131 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139139*{i#139139 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#134*{c#134 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139040*{i#139040 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#100*{c#100 <- `c*`}) -- let{`c_1*` : lane_*} c_1#133*{c_1#133 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#91*{c_2#91 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#133*{c#133 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139142).0]*{i#139142 <- `i*`} + -- let{`c*` : lane_*} c#99*{c#99 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139043).0]*{i#139043 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139146*{i#139146 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#136*{c#136 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139047*{i#139047 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#102*{c#102 <- `c*`}) -- let{`c_1*` : lane_*} c_1#135*{c_1#135 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#93*{c_2#93 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#135*{c#135 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139149).0]*{i#139149 <- `i*`} + -- let{`c*` : lane_*} c#101*{c#101 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139050).0]*{i#139050 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139153*{i#139153 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#138*{c#138 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139054*{i#139054 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#104*{c#104 <- `c*`}) -- let{`c_1*` : lane_*} c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#137*{c#137 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139156).0]*{i#139156 <- `i*`} + -- let{`c*` : lane_*} c#103*{c#103 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139057).0]*{i#139057 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139160*{i#139160 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#140*{c#140 <- `c*`}) + def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139061*{i#139061 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#106*{c#106 <- `c*`}) -- let{`c_1*` : lane_*} c_1#139*{c_1#139 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#97*{c_2#97 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#139*{c#139 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139163).0]*{i#139163 <- `i*`} + -- let{`c*` : lane_*} c#105*{c#105 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139064).0]*{i#139064 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -9539,782 +10943,859 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vunop_{M : nat, v : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vbinop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + def $vrelop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#143))?{c#143 <- `c?`}) - -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))))?{c#142 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`}) - -- let{`c?` : iN?} c#144?{c#144 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#145))))?{c#145 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#149))?{c#149 <- `c?`}) - -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#148))))?{c#148 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#152))?{c#152 <- `c?`}) - -- let{`c?` : iN?} c#150?{c#150 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#151))))?{c#151 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#155))?{c#155 <- `c?`}) - -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))))?{c#154 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#158))?{c#158 <- `c?`}) - -- let{`c?` : iN?} c#156?{c#156 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#157))))?{c#157 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#161))?{c#161 <- `c?`}) - -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#160))))?{c#160 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`}) - -- let{`c?` : iN?} c#162?{c#162 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#163))))?{c#163 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#167))?{c#167 <- `c?`}) - -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#166))))?{c#166 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#170))?{c#170 <- `c?`}) - -- let{`c?` : iN?} c#168?{c#168 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#169))))?{c#169 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#173))?{c#173 <- `c?`}) - -- let{`c?` : iN?} c#171?{c#171 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#172))))?{c#172 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#176))?{c#176 <- `c?`}) - -- let{`c?` : iN?} c#174?{c#174 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#175))))?{c#175 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#179))?{c#179 <- `c?`}) - -- let{`c?` : iN?} c#177?{c#177 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#178))))?{c#178 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#182))?{c#182 <- `c?`}) - -- let{`c?` : iN?} c#180?{c#180 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#181))))?{c#181 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#185))?{c#185 <- `c?`}) - -- let{`c?` : iN?} c#183?{c#183 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#184))))?{c#184 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#188))?{c#188 <- `c?`}) - -- let{`c?` : iN?} c#186?{c#186 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#187))))?{c#187 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#191))?{c#191 <- `c?`}) - -- let{`c?` : iN?} c#189?{c#189 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#190))))?{c#190 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#194))?{c#194 <- `c?`}) - -- let{`c?` : iN?} c#192?{c#192 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#193))))?{c#193 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#197))?{c#197 <- `c?`}) - -- let{`c?` : iN?} c#195?{c#195 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#196))))?{c#196 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#200))?{c#200 <- `c?`}) - -- let{`c?` : iN?} c#198?{c#198 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#199))))?{c#199 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#203))?{c#203 <- `c?`}) - -- let{`c?` : iN?} c#201?{c#201 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#202))))?{c#202 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#206))?{c#206 <- `c?`}) - -- let{`c?` : iN?} c#204?{c#204 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#205))))?{c#205 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#209))?{c#209 <- `c?`}) - -- let{`c?` : iN?} c#207?{c#207 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#208))))?{c#208 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#212))?{c#212 <- `c?`}) - -- let{`c?` : iN?} c#210?{c#210 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#211))))?{c#211 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#215))?{c#215 <- `c?`}) - -- let{`c?` : iN?} c#213?{c#213 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#214))))?{c#214 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#218))?{c#218 <- `c?`}) - -- let{`c?` : iN?} c#216?{c#216 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#217))))?{c#217 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#221))?{c#221 <- `c?`}) - -- let{`c?` : iN?} c#219?{c#219 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#220))))?{c#220 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#224))?{c#224 <- `c?`}) - -- let{`c?` : iN?} c#222?{c#222 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#223))))?{c#223 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#227))?{c#227 <- `c?`}) - -- let{`c?` : iN?} c#225?{c#225 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#226))))?{c#226 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#230))?{c#230 <- `c?`}) - -- let{`c?` : iN?} c#228?{c#228 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#229))))?{c#229 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#233))?{c#233 <- `c?`}) - -- let{`c?` : iN?} c#231?{c#231 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#232))))?{c#232 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#236))?{c#236 <- `c?`}) - -- let{`c?` : iN?} c#234?{c#234 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#235))))?{c#235 <- `c?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#239))*{c#239 <- `c*`} - -- let{`c*` : fN*} c#237*{c#237 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#238))))*{c#238 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#242))*{c#242 <- `c*`} - -- let{`c*` : fN*} c#240*{c#240 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#241))))*{c#241 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#245))*{c#245 <- `c*`} - -- let{`c*` : fN*} c#243*{c#243 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#244))))*{c#244 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#248))*{c#248 <- `c*`} - -- let{`c*` : fN*} c#246*{c#246 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#247))))*{c#247 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#251))*{c#251 <- `c*`} - -- let{`c*` : fN*} c#249*{c#249 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#250))))*{c#250 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#254))*{c#254 <- `c*`} - -- let{`c*` : fN*} c#252*{c#252 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#253))))*{c#253 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#257))*{c#257 <- `c*`} - -- let{`c*` : fN*} c#255*{c#255 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#256))))*{c#256 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#260))*{c#260 <- `c*`} - -- let{`c*` : fN*} c#258*{c#258 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#259))))*{c#259 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#263))*{c#263 <- `c*`} - -- let{`c*` : fN*} c#261*{c#261 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#262))))*{c#262 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#266))*{c#266 <- `c*`} - -- let{`c*` : fN*} c#264*{c#264 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#265))))*{c#265 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#269))*{c#269 <- `c*`} - -- let{`c*` : fN*} c#267*{c#267 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#268))))*{c#268 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#272))*{c#272 <- `c*`} - -- let{`c*` : fN*} c#270*{c#270 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#271))))*{c#271 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#275))*{c#275 <- `c*`} - -- let{`c*` : fN*} c#273*{c#273 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#274))))*{c#274 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#278))*{c#278 <- `c*`} - -- let{`c*` : fN*} c#276*{c#276 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#277))))*{c#277 <- `c*`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#281))*{c#281 <- `c*`} - -- let{`c*` : fN*} c#279*{c#279 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#280))))*{c#280 <- `c*`} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#108))?{c#108 <- `c?`}) + -- let{`c?` : iN?} c#107?{c#107 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#110))?{c#110 <- `c?`}) + -- let{`c?` : iN?} c#109?{c#109 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#112))?{c#112 <- `c?`}) + -- let{`c?` : iN?} c#111?{c#111 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#114))?{c#114 <- `c?`}) + -- let{`c?` : iN?} c#113?{c#113 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#116))?{c#116 <- `c?`}) + -- let{`c?` : iN?} c#115?{c#115 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#118))?{c#118 <- `c?`}) + -- let{`c?` : iN?} c#117?{c#117 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#120))?{c#120 <- `c?`}) + -- let{`c?` : iN?} c#119?{c#119 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#122))?{c#122 <- `c?`}) + -- let{`c?` : iN?} c#121?{c#121 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#124))?{c#124 <- `c?`}) + -- let{`c?` : iN?} c#123?{c#123 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#126))?{c#126 <- `c?`}) + -- let{`c?` : iN?} c#125?{c#125 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#128))?{c#128 <- `c?`}) + -- let{`c?` : iN?} c#127?{c#127 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#130))?{c#130 <- `c?`}) + -- let{`c?` : iN?} c#129?{c#129 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#132))?{c#132 <- `c?`}) + -- let{`c?` : iN?} c#131?{c#131 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#134))?{c#134 <- `c?`}) + -- let{`c?` : iN?} c#133?{c#133 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#136))?{c#136 <- `c?`}) + -- let{`c?` : iN?} c#135?{c#135 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#138))?{c#138 <- `c?`}) + -- let{`c?` : iN?} c#137?{c#137 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#140))?{c#140 <- `c?`}) + -- let{`c?` : iN?} c#139?{c#139 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))?{c#142 <- `c?`}) + -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#144))?{c#144 <- `c?`}) + -- let{`c?` : iN?} c#143?{c#143 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`}) + -- let{`c?` : iN?} c#145?{c#145 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#148))?{c#148 <- `c?`}) + -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#150))?{c#150 <- `c?`}) + -- let{`c?` : iN?} c#149?{c#149 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#152))?{c#152 <- `c?`}) + -- let{`c?` : iN?} c#151?{c#151 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))?{c#154 <- `c?`}) + -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#156))?{c#156 <- `c?`}) + -- let{`c?` : iN?} c#155?{c#155 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#158))?{c#158 <- `c?`}) + -- let{`c?` : iN?} c#157?{c#157 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#160))?{c#160 <- `c?`}) + -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#162))?{c#162 <- `c?`}) + -- let{`c?` : iN?} c#161?{c#161 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`}) + -- let{`c?` : iN?} c#163?{c#163 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#166))?{c#166 <- `c?`}) + -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#168))?{c#168 <- `c?`}) + -- let{`c?` : iN?} c#167?{c#167 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#170))?{c#170 <- `c?`}) + -- let{`c?` : iN?} c#169?{c#169 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#172))*{c#172 <- `c*`} + -- let{`c*` : fN*} c#171*{c#171 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#174))*{c#174 <- `c*`} + -- let{`c*` : fN*} c#173*{c#173 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#176))*{c#176 <- `c*`} + -- let{`c*` : fN*} c#175*{c#175 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#178))*{c#178 <- `c*`} + -- let{`c*` : fN*} c#177*{c#177 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#180))*{c#180 <- `c*`} + -- let{`c*` : fN*} c#179*{c#179 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#182))*{c#182 <- `c*`} + -- let{`c*` : fN*} c#181*{c#181 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#184))*{c#184 <- `c*`} + -- let{`c*` : fN*} c#183*{c#183 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#186))*{c#186 <- `c*`} + -- let{`c*` : fN*} c#185*{c#185 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#188))*{c#188 <- `c*`} + -- let{`c*` : fN*} c#187*{c#187 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#190))*{c#190 <- `c*`} + -- let{`c*` : fN*} c#189*{c#189 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#192))*{c#192 <- `c*`} + -- let{`c*` : fN*} c#191*{c#191 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#194))*{c#194 <- `c*`} + -- let{`c*` : fN*} c#193*{c#193 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#196))*{c#196 <- `c*`} + -- let{`c*` : fN*} c#195*{c#195 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#198))*{c#198 <- `c*`} + -- let{`c*` : fN*} c#197*{c#197 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#200))*{c#200 <- `c*`} + -- let{`c*` : fN*} c#199*{c#199 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#202))*{c#202 <- `c*`} + -- let{`c*` : fN*} c#201*{c#201 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#284))*{c#284 <- `c*`} - -- let{`c*` : fN*} c#282*{c#282 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#283))))*{c#283 <- `c*`} + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = $lcvtop__(shape_1, shape_2, vcvtop__, lane_)) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v + def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M_0)), vcvtop, v_1) = v -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) -- let{`c_1*` : lane_*} c_1#141*{c_1#141 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#285*{c#285 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142)*{c_1#142 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#286*{c#286 <- `c*#30`})*{`c*#30` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#203*{c#203 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142)*{c_1#142 <- `c_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) -- let{`c_1*` : lane_*} c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c#287*{c#287 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#288*{c#288 <- `c*#32`})*{`c*#32` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#205*{c#205 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- `c_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) -- let{`c_1*` : lane_*} c_1#145*{c_1#145 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c#289*{c#289 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#290*{c#290 <- `c*#34`})*{`c*#34` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#207*{c#207 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + def $vshiftop_{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139845*{i#139845 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139530*{i#139530 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ @@ -10498,386 +11979,316 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139991*{i#139991 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139992).0*{i#139992 <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1#2)))*{j_1#2 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2#2)))*{j_2#2 <- `j_2*`} + def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139675*{i#139675 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139676).0*{i#139676 <- `i*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#293)*{c#293 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#210)*{c#210 <- `c*`}) -- let{`c_1*` : lane_*} c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#49*{c'_1#49 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`} - -- let{`c*` : iN*} c#291*{c#291 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#292)))*{c#292 <- `c*`} + -- let{`c*` : iN*} c#209*{c#209 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#296)*{c#296 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#212)*{c#212 <- `c*`}) -- let{`c_1*` : lane_*} c_1#181*{c_1#181 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#51*{c'_1#51 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- `c_1*`} - -- let{`c*` : iN*} c#294*{c#294 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#295)))*{c#295 <- `c*`} + -- let{`c*` : iN*} c#211*{c#211 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#299)*{c#299 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#214)*{c#214 <- `c*`}) -- let{`c_1*` : lane_*} c_1#183*{c_1#183 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- `c_1*`} - -- let{`c*` : iN*} c#297*{c#297 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#298)))*{c#298 <- `c*`} + -- let{`c*` : iN*} c#213*{c#213 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#302)*{c#302 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#216)*{c#216 <- `c*`}) -- let{`c_1*` : lane_*} c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#55*{c'_1#55 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`} - -- let{`c*` : iN*} c#300*{c#300 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#301)))*{c#301 <- `c*`} + -- let{`c*` : iN*} c#215*{c#215 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#305)*{c#305 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#218)*{c#218 <- `c*`}) -- let{`c_1*` : lane_*} c_1#187*{c_1#187 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#57*{c'_1#57 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- `c_1*`} - -- let{`c*` : iN*} c#303*{c#303 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#304)))*{c#304 <- `c*`} + -- let{`c*` : iN*} c#217*{c#217 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#308)*{c#308 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#220)*{c#220 <- `c*`}) -- let{`c_1*` : lane_*} c_1#189*{c_1#189 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- `c_1*`} - -- let{`c*` : iN*} c#306*{c#306 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#307)))*{c#307 <- `c*`} + -- let{`c*` : iN*} c#219*{c#219 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#311)*{c#311 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#222)*{c#222 <- `c*`}) -- let{`c_1*` : lane_*} c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#61*{c'_1#61 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`} - -- let{`c*` : iN*} c#309*{c#309 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#310)))*{c#310 <- `c*`} + -- let{`c*` : iN*} c#221*{c#221 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#314)*{c#314 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#224)*{c#224 <- `c*`}) -- let{`c_1*` : lane_*} c_1#193*{c_1#193 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#63*{c'_1#63 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- `c_1*`} - -- let{`c*` : iN*} c#312*{c#312 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#313)))*{c#313 <- `c*`} + -- let{`c*` : iN*} c#223*{c#223 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#317)*{c#317 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#226)*{c#226 <- `c*`}) -- let{`c_1*` : lane_*} c_1#195*{c_1#195 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- `c_1*`} - -- let{`c*` : iN*} c#315*{c#315 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#316)))*{c#316 <- `c*`} + -- let{`c*` : iN*} c#225*{c#225 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#320)*{c#320 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#228)*{c#228 <- `c*`}) -- let{`c_1*` : lane_*} c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#67*{c'_1#67 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`} - -- let{`c*` : iN*} c#318*{c#318 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#319)))*{c#319 <- `c*`} + -- let{`c*` : iN*} c#227*{c#227 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#323)*{c#323 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#230)*{c#230 <- `c*`}) -- let{`c_1*` : lane_*} c_1#199*{c_1#199 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#69*{c'_1#69 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- `c_1*`} - -- let{`c*` : iN*} c#321*{c#321 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#322)))*{c#322 <- `c*`} + -- let{`c*` : iN*} c#229*{c#229 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#326)*{c#326 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#232)*{c#232 <- `c*`}) -- let{`c_1*` : lane_*} c_1#201*{c_1#201 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- `c_1*`} - -- let{`c*` : iN*} c#324*{c#324 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#325)))*{c#325 <- `c*`} + -- let{`c*` : iN*} c#231*{c#231 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#329)*{c#329 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#234)*{c#234 <- `c*`}) -- let{`c_1*` : lane_*} c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#73*{c'_1#73 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`} - -- let{`c*` : iN*} c#327*{c#327 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#328)))*{c#328 <- `c*`} + -- let{`c*` : iN*} c#233*{c#233 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#332)*{c#332 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#236)*{c#236 <- `c*`}) -- let{`c_1*` : lane_*} c_1#205*{c_1#205 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#75*{c'_1#75 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- `c_1*`} - -- let{`c*` : iN*} c#330*{c#330 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#331)))*{c#331 <- `c*`} + -- let{`c*` : iN*} c#235*{c#235 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#335)*{c#335 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#238)*{c#238 <- `c*`}) -- let{`c_1*` : lane_*} c_1#207*{c_1#207 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- `c_1*`} - -- let{`c*` : iN*} c#333*{c#333 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#334)))*{c#334 <- `c*`} + -- let{`c*` : iN*} c#237*{c#237 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#338)*{c#338 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#240)*{c#240 <- `c*`}) -- let{`c_1*` : lane_*} c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#79*{c'_1#79 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`} - -- let{`c*` : iN*} c#336*{c#336 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#337)))*{c#337 <- `c*`} + -- let{`c*` : iN*} c#239*{c#239 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#1*{i_1#1 <- `i_1*`}, i_2#1*{i_2#1 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#4))*{j_1#4 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#4))*{j_2#4 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#3*{i_1#3 <- `i_1*`}, i_2#3*{i_2#3 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#5 j_2#5]*{j_1#5 <- `j_1*`, j_2#5 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#6))*{j_1#6 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#6))*{j_2#6 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#341)*{c#341 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#242)*{c#242 <- `c*`}) -- let{`c_1*` : lane_*} c_1#211*{c_1#211 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#81*{c'_1#81 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#49*{c'_2#49 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`} - -- let{`c*` : iN*} c#339*{c#339 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#340)))*{c#340 <- `c*`} + -- let{`c*` : iN*} c#241*{c#241 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#344)*{c#344 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#244)*{c#244 <- `c*`}) -- let{`c_1*` : lane_*} c_1#213*{c_1#213 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#133*{c_2#133 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#51*{c'_2#51 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- `c_2*`} - -- let{`c*` : iN*} c#342*{c#342 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#343)))*{c#343 <- `c*`} + -- let{`c*` : iN*} c#243*{c#243 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#347)*{c#347 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#246)*{c#246 <- `c*`}) -- let{`c_1*` : lane_*} c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#135*{c_2#135 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#85*{c'_1#85 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- `c_2*`} - -- let{`c*` : iN*} c#345*{c#345 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#346)))*{c#346 <- `c*`} + -- let{`c*` : iN*} c#245*{c#245 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#350)*{c#350 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#248)*{c#248 <- `c*`}) -- let{`c_1*` : lane_*} c_1#217*{c_1#217 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#87*{c'_1#87 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#55*{c'_2#55 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`} - -- let{`c*` : iN*} c#348*{c#348 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#349)))*{c#349 <- `c*`} + -- let{`c*` : iN*} c#247*{c#247 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#353)*{c#353 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#250)*{c#250 <- `c*`}) -- let{`c_1*` : lane_*} c_1#219*{c_1#219 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#139*{c_2#139 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#57*{c'_2#57 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- `c_2*`} - -- let{`c*` : iN*} c#351*{c#351 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#352)))*{c#352 <- `c*`} + -- let{`c*` : iN*} c#249*{c#249 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#356)*{c#356 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#252)*{c#252 <- `c*`}) -- let{`c_1*` : lane_*} c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#141*{c_2#141 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#91*{c'_1#91 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- `c_2*`} - -- let{`c*` : iN*} c#354*{c#354 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#355)))*{c#355 <- `c*`} + -- let{`c*` : iN*} c#251*{c#251 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#359)*{c#359 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#254)*{c#254 <- `c*`}) -- let{`c_1*` : lane_*} c_1#223*{c_1#223 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#93*{c'_1#93 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#61*{c'_2#61 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`} - -- let{`c*` : iN*} c#357*{c#357 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#358)))*{c#358 <- `c*`} + -- let{`c*` : iN*} c#253*{c#253 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#362)*{c#362 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#256)*{c#256 <- `c*`}) -- let{`c_1*` : lane_*} c_1#225*{c_1#225 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#145*{c_2#145 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#63*{c'_2#63 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- `c_2*`} - -- let{`c*` : iN*} c#360*{c#360 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#361)))*{c#361 <- `c*`} + -- let{`c*` : iN*} c#255*{c#255 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#365)*{c#365 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#258)*{c#258 <- `c*`}) -- let{`c_1*` : lane_*} c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#147*{c_2#147 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#97*{c'_1#97 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- `c_2*`} - -- let{`c*` : iN*} c#363*{c#363 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#364)))*{c#364 <- `c*`} + -- let{`c*` : iN*} c#257*{c#257 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#368)*{c#368 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#260)*{c#260 <- `c*`}) -- let{`c_1*` : lane_*} c_1#229*{c_1#229 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#99*{c'_1#99 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#67*{c'_2#67 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`} - -- let{`c*` : iN*} c#366*{c#366 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#367)))*{c#367 <- `c*`} + -- let{`c*` : iN*} c#259*{c#259 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#371)*{c#371 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#262)*{c#262 <- `c*`}) -- let{`c_1*` : lane_*} c_1#231*{c_1#231 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#151*{c_2#151 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#69*{c'_2#69 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- `c_2*`} - -- let{`c*` : iN*} c#369*{c#369 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#370)))*{c#370 <- `c*`} + -- let{`c*` : iN*} c#261*{c#261 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#374)*{c#374 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#264)*{c#264 <- `c*`}) -- let{`c_1*` : lane_*} c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#153*{c_2#153 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#103*{c'_1#103 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- `c_2*`} - -- let{`c*` : iN*} c#372*{c#372 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#373)))*{c#373 <- `c*`} + -- let{`c*` : iN*} c#263*{c#263 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#377)*{c#377 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#266)*{c#266 <- `c*`}) -- let{`c_1*` : lane_*} c_1#235*{c_1#235 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#105*{c'_1#105 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#73*{c'_2#73 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`} - -- let{`c*` : iN*} c#375*{c#375 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#376)))*{c#376 <- `c*`} + -- let{`c*` : iN*} c#265*{c#265 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#380)*{c#380 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#268)*{c#268 <- `c*`}) -- let{`c_1*` : lane_*} c_1#237*{c_1#237 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#157*{c_2#157 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#75*{c'_2#75 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- `c_2*`} - -- let{`c*` : iN*} c#378*{c#378 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#379)))*{c#379 <- `c*`} + -- let{`c*` : iN*} c#267*{c#267 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#383)*{c#383 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#270)*{c#270 <- `c*`}) -- let{`c_1*` : lane_*} c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#159*{c_2#159 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#109*{c'_1#109 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- `c_2*`} - -- let{`c*` : iN*} c#381*{c#381 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#382)))*{c#382 <- `c*`} + -- let{`c*` : iN*} c#269*{c#269 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#386)*{c#386 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#272)*{c#272 <- `c*`}) -- let{`c_1*` : lane_*} c_1#241*{c_1#241 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#111*{c'_1#111 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#79*{c'_2#79 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`} - -- let{`c*` : iN*} c#384*{c#384 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#385)))*{c#385 <- `c*`} + -- let{`c*` : iN*} c#271*{c#271 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -10888,304 +12299,207 @@ def $ivmul_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11193,14 +12507,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11208,14 +12523,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11223,14 +12539,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11238,14 +12555,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11253,14 +12571,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11268,14 +12587,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11283,14 +12603,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11298,14 +12619,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11313,14 +12635,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11328,14 +12651,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11343,14 +12667,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11358,14 +12683,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11373,14 +12699,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11388,14 +12715,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11403,14 +12731,15 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11418,6 +12747,8 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11816,13 +13147,21 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval? def $packfield_{val : val}(I32_storagetype, val) = ?($fieldval_val(val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11967,13 +13306,21 @@ def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? def $unpackfield_{numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -12044,11 +13391,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -12059,61 +13424,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -12124,123 +13597,337 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b#1*{b#1 <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b#2*{b#2 <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r#1*{r#1 <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r#2*{r#2 <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#3*{b#3 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b#4*{b#4 <- `b*`}], $fof(z))) + def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#2*{b#2 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst{z : state, `si*` : structinst*}(z, si#1*{si#1 <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si#2*{si#2 <- `si*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai#1*{ai#1 <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai#2*{ai#2 <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn#1*{exn#1 <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn#2*{exn#2 <- `exn*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? @@ -12251,27 +13938,44 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !($growtable(tableinst, nat, ref))) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem(meminst : meminst, nat : nat) : meminst? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#7*{b#7 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#9*{b#9 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !($growmem(meminst, nat))) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -12310,7 +14014,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) @@ -12319,7 +14022,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) @@ -12328,7 +14030,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) @@ -12337,7 +14038,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) @@ -12432,7 +14132,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 rule tag{s : store, a : addr, taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) @@ -12440,7 +14139,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 rule global{s : store, a : addr, globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) @@ -12448,7 +14146,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 rule mem{s : store, a : addr, meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) @@ -12456,7 +14153,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 rule table{s : store, a : addr, tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) @@ -12464,7 +14160,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, funcinst : funcinst}: `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) @@ -12486,26 +14181,76 @@ def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = $inst_valtype(moduleinst, valtype)) + -- wf_valtype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- moduleinst.TYPES_moduleinst}) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = $inst_reftype(moduleinst, reftype)) + -- wf_reftype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- moduleinst.TYPES_moduleinst}) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = $inst_globaltype(moduleinst, globaltype)) + -- wf_globaltype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}) + def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $inst_memtype(moduleinst, memtype)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- moduleinst.TYPES_moduleinst}) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = $inst_tabletype(moduleinst, tabletype)) + -- wf_tabletype: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12540,7 +14285,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12550,7 +14294,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_2)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12560,7 +14303,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12569,7 +14311,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12585,6 +14326,7 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) -- if ($proj_uN_0(l).0 = 0) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: @@ -12602,7 +14344,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-true`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12611,7 +14352,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-false`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12620,7 +14360,6 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `br_table-lt`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])) @@ -12628,7 +14367,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) @@ -12686,11 +14424,13 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `frame-vals`{n : n, f : frame, `val*` : val*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})], $instr_val(val)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: @@ -12745,7 +14485,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.i31`{i : num_}: `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`REF.I31`_instr) -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) @@ -12865,8 +14604,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (|$unop_(nt, unop, c_1)| > 0) -- if (c <- $unop_(nt, unop, c_1)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) @@ -12875,6 +14614,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) -- if ($unop_(nt, unop, c_1) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $unop_(nt, unop, c_1)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) @@ -12882,8 +14622,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -12893,6 +14633,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) -- if ($binop_(nt, binop, c_1, c_2) = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- $binop_(nt, binop, c_1, c_2)} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) @@ -12901,8 +14642,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12910,8 +14651,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) @@ -12920,8 +14661,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (|$cvtop__(nt_1, nt_2, cvtop, c_1)| > 0) -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) @@ -12930,6 +14671,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- $cvtop__(nt_1, nt_2, cvtop, c_1)} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) @@ -12937,8 +14679,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12946,8 +14688,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -12956,8 +14698,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12967,8 +14709,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12976,8 +14718,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vunop_(sh, vunop, c_1)| > 0) -- if (c <- $vunop_(sh, vunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12986,6 +14728,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) -- if ($vunop_(sh, vunop, c_1) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vunop_(sh, vunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) @@ -12993,8 +14736,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -13004,6 +14747,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vbinop_(sh, vbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) @@ -13012,8 +14756,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vternop_(sh, vternop, c_1, c_2, c_3)| > 0) -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -13024,6 +14768,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- (wf_uN: `%%`(128, iter))*{iter <- $vternop_(sh, vternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -13034,10 +14779,10 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) - -- if ($proj_num__0(c) =/= ?()) - -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -13047,6 +14792,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- wf_uN: `%%`(128, $vrelop_(sh, vrelop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) @@ -13055,8 +14801,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- wf_uN: `%%`(128, $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) @@ -13065,8 +14811,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, $vbitmaskop_(sh, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -13075,6 +14821,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- wf_uN: `%%`(128, $vswizzlop_(sh, swizzlop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) @@ -13084,6 +14831,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- wf_uN: `%%`(128, $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) @@ -13093,6 +14841,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -13101,8 +14851,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)|) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -13112,10 +14862,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) - -- if ($proj_num__0(c_2) =/= ?()) - -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)|) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -13125,6 +14874,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -13135,6 +14887,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- wf_uN: `%%`(128, $vextunop__(sh_1, sh_2, vextunop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -13143,6 +14896,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- wf_uN: `%%`(128, $vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) @@ -13152,6 +14906,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- wf_uN: `%%`(128, $vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -13162,6 +14917,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- wf_uN: `%%`(128, $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) @@ -13171,6 +14927,7 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- wf_uN: `%%`(128, $vcvtop__(sh_1, sh_2, vcvtop, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -13179,12 +14936,20 @@ relation Step_pure: `%~>%`(instr*, instr*) def $blocktype_(state : state, blocktype : blocktype) : instrtype ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), [], `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#2*{t_1#2 <- `t_1*`}), `%`_resulttype(t_2#2*{t_2#2 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t#1?{t#1 <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t#2?{t#2 <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = $blocktype_(state, blocktype)) + -- wf_instrtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) @@ -13192,6 +14957,7 @@ relation `Step_read_before_br_on_cast-fail`: `%`(config) rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -13201,6 +14967,7 @@ relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13221,11 +14988,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13233,11 +14999,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -13246,8 +15011,8 @@ relation `Step_read_before_table.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13256,9 +15021,9 @@ relation `Step_read_before_table.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13274,9 +15039,9 @@ relation `Step_read_before_table.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13286,8 +15051,6 @@ relation `Step_read_before_table.copy-gt`: `%`(config) rule `table.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) @@ -13309,9 +15072,9 @@ relation `Step_read_before_table.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13320,9 +15083,9 @@ relation `Step_read_before_table.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13331,8 +15094,8 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13341,9 +15104,9 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13359,9 +15122,9 @@ relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13370,9 +15133,9 @@ relation `Step_read_before_memory.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13382,6 +15145,7 @@ relation `Step_read_before_ref.test-false`: `%`(config) rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -13391,6 +15155,7 @@ relation `Step_read_before_ref.cast-fail`: `%`(config) rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13398,9 +15163,25 @@ relation `Step_read_before_array.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13409,18 +15190,16 @@ relation `Step_read_before_array.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13436,18 +15215,16 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13458,9 +15235,6 @@ relation `Step_read_before_array.copy-gt`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -13485,18 +15259,16 @@ relation `Step_read_before_array.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13505,17 +15277,41 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13525,9 +15321,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13535,9 +15330,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13554,9 +15348,8 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13564,9 +15357,8 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13576,22 +15368,31 @@ relation Step_read: `%~>%`(config, instr*) rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) @@ -13605,6 +15406,7 @@ relation Step_read: `%~>%`(config, instr*) rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt_2)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13617,9 +15419,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) @@ -13633,24 +15434,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) - -- if (a < |$funcinst(z)|) -- if ($funcinst(z)[a] = fi) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) @@ -13676,12 +15478,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) - -- if (a < |$funcinst(z)|) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-null`{z : state}: @@ -13721,22 +15526,20 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13765,15 +15568,20 @@ relation Step_read: `%~>%`(config, instr*) rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`($blocktype_(z, bt)) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13781,13 +15589,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13795,7 +15604,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [$instr_ref($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) - -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13803,6 +15612,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -13810,15 +15620,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13826,7 +15635,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13839,9 +15647,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13855,8 +15663,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) @@ -13872,8 +15678,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) @@ -13888,17 +15692,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) @@ -13906,11 +15708,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -13922,86 +15722,94 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) @@ -14010,37 +15818,42 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) @@ -14051,6 +15864,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -14058,15 +15872,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -14074,7 +15887,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -14087,17 +15899,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) @@ -14105,8 +15915,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) @@ -14123,8 +15931,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) @@ -14141,17 +15947,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -14159,9 +15963,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -14182,7 +15983,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.func`{z : state, x : idx}: `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) @@ -14190,6 +15990,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -14204,6 +16005,7 @@ relation Step_read: `%~>%`(config, instr*) rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- wf_reftype: `%`($inst_reftype(f.MODULE_frame, rt)) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14217,10 +16019,10 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`val*`| = |`zt*`|) - -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- `zt*`} -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14234,11 +16036,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) - -- if ($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) - -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) - -- if (a < |$structinst(z)|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14246,9 +16046,10 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14256,27 +16057,27 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), $instr_ref(ref)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- if (n = |`ref*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(i) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14284,15 +16085,18 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- (if ($cunpack(zt) =/= ?()))^n{} -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zsize(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (n = |`c*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -14303,20 +16107,17 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) - -- if ($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if (a < |$arrayinst(z)|) - -- if ($proj_num__0(i) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14329,7 +16130,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-array`{z : state, a : addr}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) - -- if (a < |$arrayinst(z)|) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) @@ -14342,28 +16142,22 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (n =/= 0) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14387,45 +16181,31 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (n =/= 0) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14443,11 +16223,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_array.copy-gt`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14471,43 +16248,33 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ($proj_num__0(j) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_ref(ref) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14526,9 +16293,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -14536,9 +16302,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14553,14 +16318,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- if ($cunpack(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- ~ `Step_read_before_array.init_data-num`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14630,15 +16395,17 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (n = |`val*`|) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule `local.set`{z : state, val : val, x : idx}: @@ -14655,24 +16422,25 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) -- if (ti = !($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`(!($growtable($table(z, x), n, ref))) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) @@ -14691,69 +16459,67 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(c) =/= ?()) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) - -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)|) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) @@ -14761,8 +16527,9 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) -- if (mi = !($growmem($mem(z, x), n))) + -- wf_meminst: `%`(!($growmem($mem(z, x), n))) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) @@ -14783,12 +16550,17 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- if (n = |`val*`|) + -- if (n = |`mut?*`|) + -- if (n = |`zt*`|) + -- if (n = |`val*`|) + -- if (n = |`zt*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: @@ -14799,8 +16571,6 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) - -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) @@ -14810,12 +16580,13 @@ relation Step: `%~>%`(config, config) rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: @@ -14826,17 +16597,14 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($packfield_(zt, val) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) @@ -14893,9 +16661,18 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = $alloctag(store, tagtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14909,14 +16686,38 @@ def $alloctags(store : store, tagtype*) : (store, tagaddr*) -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = $alloctags(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $alloctags(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = $allocglobal(store, globaltype, val)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14930,14 +16731,38 @@ def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = $allocglobals(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $allocglobals(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $allocmem(store, memtype)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14951,14 +16776,38 @@ def $allocmems(store : store, memtype*) : (store, memaddr*) -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = $allocmems(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocmems(store, var_0)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = $alloctable(store, tabletype, ref)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14972,14 +16821,39 @@ def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = $alloctables(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $alloctables(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = $allocfunc(store, deftype, funccode, moduleinst)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -14993,14 +16867,38 @@ def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funca -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = $allocfuncs(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = $allocfuncs(store, var_0, var_1, var_2)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte#2*{byte#2 <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) -- if (datainst = {BYTES byte#3*{byte#3 <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte#4*{byte#4 <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocdata(store, datatype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -15009,19 +16907,43 @@ def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 def $allocdatas{s : store}(s, [], []) = (s, []) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#10*{b#10 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b#11*{b#11 <- `b*`}) + def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#8*{b#8 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) + -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b#9*{b#9 <- `b*`}) -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = $allocdatas(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocdatas(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref#1*{ref#1 <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) -- if (eleminst = {TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocelem(store, elemtype, var_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -15035,41 +16957,71 @@ def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = $allocelems(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $allocelems(store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#4*{export#4 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#3*{export#3 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#4*{global#4 <- `global*`}), `%`_list(mem#4*{mem#4 <- `mem*`}), `%`_list(table#4*{table#4 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#4*{elem#4 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#5*{export#5 <- `export*`})) = module + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#4*{export#4 <- `export*`})) = module -- if (tag#3*{tag#3 <- `tag*`} = TAG_tag(tagtype#78)*{tagtype#78 <- `tagtype*`}) - -- if (global#5*{global#5 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) - -- if (mem#5*{mem#5 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) - -- if (table#5*{table#5 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) + -- if (global#4*{global#4 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) + -- if (mem#4*{mem#4 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) + -- if (table#4*{table#4 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) -- if (func#4*{func#4 <- `func*`} = FUNC_func(x#2, local#2*{local#2 <- `local*#82`}, expr_F#1)*{expr_F#1 <- `expr_F*`, `local*#82` <- `local**`, x#2 <- `x*`}) -- if (data#3*{data#3 <- `data*`} = DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`}) - -- if (elem#5*{elem#5 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) + -- if (elem#4*{elem#4 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`}) -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`}) -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`}) @@ -15084,11 +17036,9 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = $allocdatas(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}) -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`})*{elemtype#2 <- `elemtype*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}) -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = $allocfuncs(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{})) - -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#6*{export#6 <- `export*`})) + -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#5*{export#5 <- `export*`})) -- if (moduleinst = {TYPES dt#15*{dt#15 <- `dt*`}, TAGS aa_I#3*{aa_I#3 <- `aa_I*`} ++ aa#3*{aa#3 <- `aa*`}, GLOBALS ga_I#3*{ga_I#3 <- `ga_I*`} ++ ga#3*{ga#3 <- `ga*`}, MEMS ma_I#3*{ma_I#3 <- `ma_I*`} ++ ma#3*{ma#3 <- `ma*`}, TABLES ta_I#3*{ta_I#3 <- `ta_I*`} ++ ta#3*{ta#3 <- `ta*`}, FUNCS fa_I#3*{fa_I#3 <- `fa_I*`} ++ fa#4*{fa#4 <- `fa*`}, DATAS da#2*{da#2 <- `da*`}, ELEMS ea#2*{ea#2 <- `ea*`}, EXPORTS xi#2*{xi#2 <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- `expr_G*`, globaltype#125 <- `globaltype*`} -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- `memtype*`} @@ -15099,30 +17049,60 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#4*{aa_I#4 <- `aa_I*`} ++ aa#4*{aa#4 <- `aa*`}, GLOBALS ga_I#4*{ga_I#4 <- `ga_I*`} ++ ga#4*{ga#4 <- `ga*`}, MEMS ma_I#4*{ma_I#4 <- `ma_I*`} ++ ma#4*{ma#4 <- `ma*`}, TABLES ta_I#4*{ta_I#4 <- `ta_I*`} ++ ta#4*{ta#4 <- `ta*`}, FUNCS fa_I#4*{fa_I#4 <- `fa_I*`} ++ fa#5*{fa#5 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt#16*{dt#16 <- `dt*`}, TAGS aa_I#5*{aa_I#5 <- `aa_I*`} ++ aa#5*{aa#5 <- `aa*`}, GLOBALS ga_I#5*{ga_I#5 <- `ga_I*`} ++ ga#5*{ga#5 <- `ga*`}, MEMS ma_I#5*{ma_I#5 <- `ma_I*`} ++ ma#5*{ma#5 <- `ma*`}, TABLES ta_I#5*{ta_I#5 <- `ta_I*`} ++ ta#5*{ta#5 <- `ta*`}, FUNCS fa_I#5*{fa_I#5 <- `fa_I*`} ++ fa#6*{fa#6 <- `fa*`}, DATAS da#3*{da#3 <- `da*`}, ELEMS ea#3*{ea#3 <- `ea*`}, EXPORTS xi#3*{xi#3 <- `xi*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = $allocmodule(store, module, var_0, var_1, var_2, var_3)) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $rundata_(dataidx : dataidx, data : data) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b#12^n{b#12 <- `b*`}, PASSIVE_datamode)) = [] + def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b#10*{b#10 <- `b*`}, PASSIVE_datamode)) = [] + -- if (n = |`b*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b#13^n{b#13 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b#11*{b#11 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] + -- if (n = |`b*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = $rundata_(dataidx, data)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $runelem_(elemidx : elemidx, elem : elem) : instr* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#1^n{e#1 <- `e*`}, PASSIVE_elemmode)) = [] + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#1*{e#1 <- `e*`}, PASSIVE_elemmode)) = [] + -- if (n = |`e*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#2^n{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#2*{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] + -- if (n = |`e*`|) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e#3^n{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e#3*{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] + -- if (n = |`e*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = $runelem_(elemidx, elem)) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { @@ -15135,13 +17115,27 @@ def $evalexprs(state : state, expr*) : (state, ref*) def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = $evalexprs(z', expr'#2*{expr'#2 <- `expr'*`}) - -- wf_ref: `%`(ref) -- wf_state: `%`(z') } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprs(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 @@ -15155,6 +17149,21 @@ def $evalexprss(state : state, expr**) : (state, ref**) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = $evalexprss(state, var_0)) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 def $evalglobals(state : state, globaltype*, expr*) : (state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 @@ -15165,24 +17174,39 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- let{s : store, f : frame} `%;%`_state(s, f) = z' -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}) - -- wf_val: `%`(val) -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) } +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = $evalglobals(state, var_0, var_1)) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate(store : store, module : module, externaddr*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- `externaddr*`, xt_I#2 <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#7*{global#7 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#7*{table#7 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#7*{elem#7 <- `elem*`}), start#6?{start#6 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`})) = module - -- if (global#8*{global#8 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) - -- if (table#8*{table#8 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`})) = module + -- if (global#7*{global#7 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) + -- if (table#7*{table#7 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) -- if (data#7*{data#7 <- `data*`} = DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`}) - -- if (elem#8*{elem#8 <- `elem*`} = ELEM_elem(reftype#517, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#517 <- `reftype*`}) - -- if (start#7?{start#7 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) + -- if (elem#7*{elem#7 <- `elem*`} = ELEM_elem(reftype#516, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#516 <- `reftype*`}) + -- if (start#6?{start#6 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) -- if (moduleinst_0 = {TYPES $alloctypes(type#6*{type#6 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#9*{externaddr#9 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#10*{externaddr#10 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = $evalglobals(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}) @@ -15191,32 +17215,50 @@ def $instantiate(store : store, module : module, externaddr*) : config -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1])^(i_D#1<|data#8*{data#8 <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem#10*{elem#10 <- `elem*`}[i_E#1])^(i_E#1<|elem#9*{elem#9 <- `elem*`}|){}) + -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem#9*{elem#9 <- `elem*`}[i_E#1])^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){}) -- let{`instr_S?` : instr?} instr_S#1?{instr_S#1 <- `instr_S?`} = CALL_instr(x#7)?{x#7 <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E#2*{instr_E#2 <- `instr_E*`} ++ instr_D#2*{instr_D#2 <- `instr_D*`} ++ lift(instr_S#2?{instr_S#2 <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#3*{xt_I#3 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#9*{global#9 <- `global*`}), `%`_list(mem#8*{mem#8 <- `mem*`}), `%`_list(table#9*{table#9 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#11*{elem#11 <- `elem*`}), start#8?{start#8 <- `start?`}, `%`_list(export#9*{export#9 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#8*{global#8 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#10*{elem#10 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- `expr_G*`, globaltype#130 <- `globaltype*`} -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- `expr_T*`, tabletype#163 <- `tabletype*`} -- (wf_data: `%`(DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)))*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype#519, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#519 <- `reftype*`} + -- (wf_elem: `%`(ELEM_elem(reftype#518, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#518 <- `reftype*`} -- (wf_start: `%`(START_start(x#8)))?{x#8 <- `x?`} -- wf_moduleinst: `%`({TYPES $alloctypes(type#8*{type#8 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#12*{externaddr#12 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#13*{externaddr#13 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data#11*{data#11 <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#12*{elem#12 <- `elem*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- `x?`} +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = $instantiate(store, module, var_0)) + -- wf_config: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke(store : store, funcaddr : funcaddr, val*) : config ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val#1*{val#1 <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val#2, t_1#7))*{t_1#7 <- `t_1*`, val#2 <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#3)*{val#3 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#8*{t_1#8 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- (Val_ok: `%|-%:%`(s, val#2, t_1#5))*{t_1#5 <- `t_1*`, val#2 <- `val*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $invoke(store, funcaddr, var_0)) + -- wf_config: `%`(ret_val) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -15236,6 +17278,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -15280,11 +17330,23 @@ rec { def $concat_idctxt(idctxt*) : idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'#1*{I'#1 <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) } +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $concat_idctxt(var_0)) + -- wf_idctxt: `%`(ret_val) +} + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec relation Idctxt_ok: `|-%:OK`(idctxt) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -15303,6 +17365,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -15450,6 +17523,19 @@ def $importsd(decl*) : import* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $importsd(var_0)) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 @@ -15463,6 +17549,19 @@ def $tagsd(decl*) : tag* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tagsd(var_0)) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 @@ -15476,6 +17575,19 @@ def $globalsd(decl*) : global* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $globalsd(var_0)) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 @@ -15489,6 +17601,19 @@ def $memsd(decl*) : mem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $memsd(var_0)) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 @@ -15502,6 +17627,19 @@ def $tablesd(decl*) : table* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $tablesd(var_0)) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 @@ -15515,6 +17653,19 @@ def $funcsd(decl*) : func* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $funcsd(var_0)) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 @@ -15528,6 +17679,19 @@ def $datasd(decl*) : data* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $datasd(var_0)) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 @@ -15541,6 +17705,19 @@ def $elemsd(decl*) : elem* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $elemsd(var_0)) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 @@ -15554,6 +17731,19 @@ def $startsd(decl*) : start* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $startsd(var_0)) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 def $exportsd(decl*) : export* ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 @@ -15564,6 +17754,19 @@ def $exportsd(decl*) : export* def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#33*{decl'#33 <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) } +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $exportsd(var_0)) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} +} + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $ordered(decl*) : bool ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -15586,8 +17789,6 @@ relation Context_ok: `|-%:OK`(context) -- (Memtype_ok: `%|-%:OK`(C_0, mt))*{mt <- `mt*`} -- (Tabletype_ok: `%|-%:OK`(C_0, tt))*{tt <- `tt*`} -- (Deftype_ok: `%|-%:OK`(C_0, dt_F))*{dt_F <- `dt_F*`} - -- if (|`dt_F*`| = |`t_1*`|) - -- if (|`dt_F*`| = |`t_2*`|) -- (Expand: `%~~%`(dt_F, `FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} @@ -15598,11 +17799,11 @@ relation Context_ok: `|-%:OK`(context) -- wf_context: `%`(C_0) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (n = |`dt*`|) + -- if (m = |`st*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) @@ -15655,25 +17856,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) rule _{s : store, `deftype*` : deftype*, `tagaddr*` : tagaddr*, `globaladdr*` : globaladdr*, `memaddr*` : memaddr*, `tableaddr*` : tableaddr*, `funcaddr*` : funcaddr*, `dataaddr*` : dataaddr*, `elemaddr*` : elemaddr*, `exportinst*` : exportinst*, `tagtype*` : tagtype*, `globaltype*` : globaltype*, `memtype*` : memtype*, `tabletype*` : tabletype*, `deftype_F*` : deftype*, `datatype*` : datatype*, `elemtype*` : elemtype*, `subtype*` : subtype*}: `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} - -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} - -- if (|`globaladdr*`| = |`globaltype*`|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} - -- if (|`deftype_F*`| = |`funcaddr*`|) -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} - -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} - -- if (|`tableaddr*`| = |`tabletype*`|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} - -- if (|`dataaddr*`| = |`datatype*`|) - -- (if (dataaddr < |s.DATAS_store|))*{dataaddr <- `dataaddr*`} -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} - -- if (|`elemaddr*`| = |`elemtype*`|) - -- (if (elemaddr < |s.ELEMS_store|))*{elemaddr <- `elemaddr*`} -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) - -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) @@ -15691,7 +17882,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) rule _{s : store, `val?*` : val?*, moduleinst : moduleinst, C : context, `lct*` : localtype*}: `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -15733,6 +17923,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) + -- if (n = |`t'*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: @@ -15744,6 +17935,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: @@ -15778,16 +17970,13 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} @@ -15896,7 +18085,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`zt*`|) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) @@ -15918,10 +18106,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) - -- if (ta < |s.TAGS_store|) -- if ($typeuse_deftype(dt) = s.TAGS_store[ta].TYPE_taginst) -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (|`t*`| = |`val*`|) -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) @@ -15945,10 +18131,7 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) - -- if (a < |s.STRUCTS_store|) -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (i < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) @@ -15958,8 +18141,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) - -- if (a < |s.ARRAYS_store|) -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) @@ -15968,8 +18149,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule `ref.exn`{a : addr, s : store, i : nat}: `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) - -- if (i < |s.EXNS_store[a].FIELDS_exninst|) - -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) @@ -16004,19 +18183,12 @@ relation Store_ok: `|-%:OK`(store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: `|-%:OK`(s) - -- if (|`taginst*`| = |`tagtype*`|) -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} - -- if (|`globalinst*`| = |`globaltype*`|) -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} - -- if (|`meminst*`| = |`memtype*`|) -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} - -- if (|`tableinst*`| = |`tabletype*`|) -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} - -- if (|`deftype*`| = |`funcinst*`|) -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} - -- if (|`datainst*`| = |`datatype*`|) -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} - -- if (|`eleminst*`| = |`elemtype*`|) -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} @@ -16103,8 +18275,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`fv'*`|) - -- if (|`fv*`| = |`mut?*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -16116,7 +18286,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?` : mut?, zt : storagetype}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -16134,35 +18303,15 @@ relation Extend_store: `%<=%`(store, store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, s' : store}: `%<=%`(s, s') - -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} - -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} - -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} - -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} - -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} - -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} - -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} - -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} - -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} - -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} - -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} - -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} - -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} - -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} - -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} - -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} - -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} - -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} - -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} - -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -16255,7 +18404,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -16299,6 +18447,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -16324,6 +18480,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -16337,6 +18502,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'#1*{a'#1 <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'#2*{X'#2 <- `X'*`}, Y'#2*{Y'#2 <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -18701,7 +20879,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -18772,7 +20950,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18781,7 +20959,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec diff --git a/spectec/test-middlend/specification.exp/12-alias-demut.il b/spectec/test-middlend/specification.exp/12-definition-to-relation.il similarity index 71% rename from spectec/test-middlend/specification.exp/12-alias-demut.il rename to spectec/test-middlend/specification.exp/12-definition-to-relation.il index dd1eb8f838..27dbe00b62 100644 --- a/spectec/test-middlend/specification.exp/12-alias-demut.il +++ b/spectec/test-middlend/specification.exp/12-definition-to-relation.il @@ -22,23 +22,31 @@ def $min(nat : nat, nat : nat) : nat ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.1-9.56 -def $sum(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:10.1-10.18 - def $sum([]) = 0 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:11.1-11.35 - def $sum{n : nat, `n'*` : n*}([n] ++ n'#1*{n'#1 <- `n'*`}) = (n + $sum(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 +relation fun_sum: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_0: + `%%`([], 0) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#1*{n'#1 <- `n'*`}, (n + var_0)) + -- fun_sum: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.1-13.57 -def $prod(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:14.1-14.19 - def $prod([]) = 1 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:15.1-15.37 - def $prod{n : nat, `n'*` : n*}([n] ++ n'#2*{n'#2 <- `n'*`}) = (n * $prod(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 +relation fun_prod: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_0: + `%%`([], 1) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#2*{n'#2 <- `n'*`}, (n * var_0)) + -- fun_prod: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -69,7 +77,9 @@ def $concatn_(syntax X, X**, nat : nat) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2^n{w#2 <- `w*`}] ++ w'#2^n{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2*{w#2 <- `w*`}] ++ w'#2*{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + -- if (n = |`w*`|) + -- (if (n = |`w'*#2`|))*{`w'*#2` <- `w'**`} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -329,19 +339,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -381,44 +412,66 @@ relation wf_char: `%`(char) -- if (((i >= 0) /\ (i <= 55295)) \/ ((i >= 57344) /\ (i <= 1114111))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -def $cont(byte : byte) : nat +relation fun_cont: `%%`(byte, nat) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - def $cont{b : byte}(b) = ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat) + rule fun_cont_case_0{b : byte}: + `%%`(b, ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat)) -- if ((128 < $proj_byte_0(b).0) /\ ($proj_byte_0(b).0 < 192)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.1-91.25 -def $utf8(char*) : byte* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:52.1-52.44 - def $utf8{`ch*` : char*}(ch#1*{ch#1 <- `ch*`}) = $concat_(syntax byte, $utf8([ch])*{ch <- `ch*`}) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:53.1-55.15 - def $utf8{ch : char}([ch]) = [b] +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation fun_utf8: `%%`(char*, byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_0{`ch*` : char*, `var_0*` : byte**}: + `%%`(ch#1*{ch#1 <- `ch*`}, $concat_(syntax byte, var_0*{var_0 <- `var_0*`})) + -- (fun_utf8: `%%`([ch], var_0))*{var_0 <- `var_0*`, ch <- `ch*`} + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_1{ch : char}: + `%%`([ch], [b]) -- if ($proj_char_0(ch).0 < 128) -- let{b : byte} b = `%`_byte($proj_char_0(ch).0) -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:56.1-58.46 - def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_2{ch : char, b_1 : byte, b_2 : byte, var_0 : nat}: + `%%`([ch], [b_1 b_2]) -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) - -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] + -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + var_0)) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_3{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3]) -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) - -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] + -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * var_0)) + var_1)) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_4{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte, var_2 : nat, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3 b_4]) -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) - -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) + -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * var_0)) + ((2 ^ 6) * var_1)) + var_2)) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*, var_1 : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + -- fun_utf8: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -433,10 +486,11 @@ def $proj_name_0(x : name) : (char*) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_name: `%`(name) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule name_case_0{`char*` : char*}: + rule name_case_0{`char*` : char*, var_0 : byte*}: `%`(`%`_name(`char*`)) -- (wf_char: `%`(char))*{char <- `char*`} - -- if (|$utf8(char*{char <- `char*`})| < (2 ^ 32)) + -- if (|var_0| < (2 ^ 32)) + -- fun_utf8: `%%`(char*{char <- `char*`}, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax idx = u32 @@ -515,66 +569,101 @@ relation wf_externidx: `%`(externidx) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.1-129.86 -def $funcsxx(externidx*) : typeidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:135.1-135.24 - def $funcsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:136.1-136.45 - def $funcsxx{x : uN, `xx*` : externidx*}([FUNC_externidx(x)] ++ xx#1*{xx#1 <- `xx*`}) = [x] ++ $funcsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:137.1-137.58 - def $funcsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx#2*{xx#2 <- `xx*`}) = $funcsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 +relation fun_funcsxx: `%%`(externidx*, typeidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_1{x : uN, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([FUNC_externidx(x)] ++ xx#1*{xx#1 <- `xx*`}, [x] ++ var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([externidx] ++ xx#2*{xx#2 <- `xx*`}, var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.1-130.88 -def $globalsxx(externidx*) : globalidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:139.1-139.26 - def $globalsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:140.1-140.51 - def $globalsxx{x : uN, `xx*` : externidx*}([GLOBAL_externidx(x)] ++ xx#3*{xx#3 <- `xx*`}) = [x] ++ $globalsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:141.1-141.62 - def $globalsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx#4*{xx#4 <- `xx*`}) = $globalsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 +relation fun_globalsxx: `%%`(externidx*, globalidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_1{x : uN, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([GLOBAL_externidx(x)] ++ xx#3*{xx#3 <- `xx*`}, [x] ++ var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([externidx] ++ xx#4*{xx#4 <- `xx*`}, var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.1-131.87 -def $tablesxx(externidx*) : tableidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:143.1-143.25 - def $tablesxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:144.1-144.48 - def $tablesxx{x : uN, `xx*` : externidx*}([TABLE_externidx(x)] ++ xx#5*{xx#5 <- `xx*`}) = [x] ++ $tablesxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:145.1-145.60 - def $tablesxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx#6*{xx#6 <- `xx*`}) = $tablesxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 +relation fun_tablesxx: `%%`(externidx*, tableidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_1{x : uN, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([TABLE_externidx(x)] ++ xx#5*{xx#5 <- `xx*`}, [x] ++ var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([externidx] ++ xx#6*{xx#6 <- `xx*`}, var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.1-132.85 -def $memsxx(externidx*) : memidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:147.1-147.23 - def $memsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:148.1-148.42 - def $memsxx{x : uN, `xx*` : externidx*}([MEM_externidx(x)] ++ xx#7*{xx#7 <- `xx*`}) = [x] ++ $memsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:149.1-149.56 - def $memsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx#8*{xx#8 <- `xx*`}) = $memsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 +relation fun_memsxx: `%%`(externidx*, memidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_1{x : uN, `xx*` : externidx*, var_0 : memidx*}: + `%%`([MEM_externidx(x)] ++ xx#7*{xx#7 <- `xx*`}, [x] ++ var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : memidx*}: + `%%`([externidx] ++ xx#8*{xx#8 <- `xx*`}, var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.1-133.85 -def $tagsxx(externidx*) : tagidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:151.1-151.23 - def $tagsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:152.1-152.42 - def $tagsxx{x : uN, `xx*` : externidx*}([TAG_externidx(x)] ++ xx#9*{xx#9 <- `xx*`}) = [x] ++ $tagsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:153.1-153.56 - def $tagsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx#10*{xx#10 <- `xx*`}) = $tagsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 +relation fun_tagsxx: `%%`(externidx*, tagidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_1{x : uN, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([TAG_externidx(x)] ++ xx#9*{xx#9 <- `xx*`}, [x] ++ var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([externidx] ++ xx#10*{xx#10 <- `xx*`}, var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,81 +701,186 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation fun_free_list: `%%`(free*, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_0: + `%%`([], {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_1{free : free, `free'*` : free*, var_0 : free}: + `%%`([free] ++ free'#1*{free'#1 <- `free'*`}, free +++ var_0) + -- fun_free_list: `%%`(free'*{free' <- `free'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.1-173.29 -def $free_list(free*) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 - def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 - def $free_list{free : free, `free'*` : free*}([free] ++ free'#1*{free'#1 <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_list: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -701,6 +895,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -813,6 +1016,9 @@ syntax storagetype = | I8 | I16 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:102.1-103.16 +syntax resulttype = list(syntax valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.1-112.61 syntax fieldtype = | `%%`(`mut?` : mut?, storagetype : storagetype) @@ -821,7 +1027,7 @@ syntax fieldtype = syntax comptype = | STRUCT(list(syntax fieldtype)) | ARRAY(fieldtype : fieldtype) - | `FUNC%->%`(resulttype : list(syntax valtype), resulttype : list(syntax valtype)) + | `FUNC%->%`(resulttype : resulttype, resulttype : resulttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:119.1-120.33 syntax subtype = @@ -832,9 +1038,6 @@ syntax rectype = | REC(list(syntax subtype)) } -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -syntax resulttype = list(syntax valtype) - def $heaptype_absheaptype(absheaptype) : heaptype def $heaptype_absheaptype(ANY_absheaptype) = ANY_heaptype def $heaptype_absheaptype(EQ_absheaptype) = EQ_heaptype @@ -1149,77 +1352,168 @@ syntax Cnn = | F64 | V128 +def $storagetype_Cnn(Cnn) : storagetype + def $storagetype_Cnn(I32_Cnn) = I32_storagetype + def $storagetype_Cnn(I64_Cnn) = I64_storagetype + def $storagetype_Cnn(F32_Cnn) = F32_storagetype + def $storagetype_Cnn(F64_Cnn) = F64_storagetype + def $storagetype_Cnn(V128_Cnn) = V128_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1290,6 +1584,7 @@ relation wf_limits: `%`(limits) rule limits_case_0{u64 : u64, `u64?` : u64?}: `%`(`[%..%]`_limits(u64, `u64?`)) -- wf_uN: `%%`(64, u64) + -- (wf_uN: `%%`(64, u64))?{u64 <- `u64?`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax tagtype = typeuse @@ -1595,10 +1890,17 @@ def $unpack(storagetype : storagetype) : valtype def $unpack(I32_storagetype) = I32_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I8_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I16_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? @@ -1664,10 +1966,18 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#1?{null_1#1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#2?{null_1#2 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? @@ -1679,85 +1989,195 @@ def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.1-308.87 -def $tagsxt(externtype*) : tagtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:314.1-314.23 - def $tagsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:315.1-315.44 - def $tagsxt{jt : typeuse, `xt*` : externtype*}([TAG_externtype(jt)] ++ xt#1*{xt#1 <- `xt*`}) = [jt] ++ $tagsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:316.1-316.57 - def $tagsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt#2*{xt#2 <- `xt*`}) = $tagsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 +relation fun_tagsxt: `%%`(externtype*, tagtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_1{jt : typeuse, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([TAG_externtype(jt)] ++ xt#1*{xt#1 <- `xt*`}, [jt] ++ var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([externtype] ++ xt#2*{xt#2 <- `xt*`}, var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.1-309.90 -def $globalsxt(externtype*) : globaltype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:318.1-318.26 - def $globalsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:319.1-319.53 - def $globalsxt{gt : globaltype, `xt*` : externtype*}([GLOBAL_externtype(gt)] ++ xt#3*{xt#3 <- `xt*`}) = [gt] ++ $globalsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:320.1-320.63 - def $globalsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt#4*{xt#4 <- `xt*`}) = $globalsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation fun_globalsxt: `%%`(externtype*, globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_1{gt : globaltype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([GLOBAL_externtype(gt)] ++ xt#3*{xt#3 <- `xt*`}, [gt] ++ var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([externtype] ++ xt#4*{xt#4 <- `xt*`}, var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 -def $memsxt(externtype*) : memtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 - def $memsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:323.1-323.44 - def $memsxt{mt : memtype, `xt*` : externtype*}([MEM_externtype(mt)] ++ xt#5*{xt#5 <- `xt*`}) = [mt] ++ $memsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:324.1-324.57 - def $memsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt#6*{xt#6 <- `xt*`}) = $memsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*, var_1 : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 -def $tablesxt(externtype*) : tabletype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 - def $tablesxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:327.1-327.50 - def $tablesxt{tt : tabletype, `xt*` : externtype*}([TABLE_externtype(tt)] ++ xt#7*{xt#7 <- `xt*`}) = [tt] ++ $tablesxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:328.1-328.61 - def $tablesxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt#8*{xt#8 <- `xt*`}) = $tablesxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation fun_memsxt: `%%`(externtype*, memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_1{mt : memtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([MEM_externtype(mt)] ++ xt#5*{xt#5 <- `xt*`}, [mt] ++ var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([externtype] ++ xt#6*{xt#6 <- `xt*`}, var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 -def $funcsxt(externtype*) : deftype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 - def $funcsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:331.1-331.47 - def $funcsxt{rectype : rectype, n : n, `xt*` : externtype*}([FUNC_externtype(_DEF_typeuse(rectype, n))] ++ xt#9*{xt#9 <- `xt*`}) = [_DEF_deftype(rectype, n)] ++ $funcsxt(xt#10*{xt#10 <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:332.1-332.59 - def $funcsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt#11*{xt#11 <- `xt*`}) = $funcsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*, var_1 : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.1-337.126 -def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:365.1-365.38 - def $subst_typevar{tv : typevar}(tv, [], []) = ?($typeuse_typevar(tv)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:366.1-366.95 - def $subst_typevar{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*}(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}) = (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- $subst_typevar(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})} - def $subst_typevar{x0 : typevar, x1 : typevar*, x2 : typeuse*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation fun_tablesxt: `%%`(externtype*, tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_1{tt : tabletype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([TABLE_externtype(tt)] ++ xt#7*{xt#7 <- `xt*`}, [tt] ++ var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([externtype] ++ xt#8*{xt#8 <- `xt*`}, var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*, var_1 : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesxt: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 +relation fun_funcsxt: `%%`(externtype*, deftype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_1{rectype : rectype, n : n, `xt*` : externtype*, var_0 : deftype*}: + `%%`([FUNC_externtype(_DEF_typeuse(rectype, n))] ++ xt#9*{xt#9 <- `xt*`}, [_DEF_deftype(rectype, n)] ++ var_0) + -- fun_funcsxt: `%%`(xt#10*{xt#10 <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : deftype*}: + `%%`([externtype] ++ xt#11*{xt#11 <- `xt*`}, var_0) + -- fun_funcsxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(typevar, typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%`(tv, [], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation fun_subst_typevar: `%%%%`(typevar, typevar*, typeuse*, typeuse?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%%`(tv, [], [], ?($typeuse_typevar(tv))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}, (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- var_0}) + -- fun_subst_typevar: `%%%%`(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_2{x0 : typevar, x1 : typevar*, x2 : typeuse*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse?}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typevar: `%%%%`(typevar, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1766,11 +2186,25 @@ def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#2*{tv'#2 <- `tv'*`}, tu'#2*{tu'#2 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1789,268 +2223,643 @@ def $subst_vectype(vectype : vectype, typevar*, typeuse*) : vectype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.1-338.112 -def $subst_typeuse(typeuse : typeuse, typevar*, typeuse*) : typeuse - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{n : n, `tv*` : typevar*, `tu*` : typeuse*}(REC_typeuse(n), tv#7*{tv#7 <- `tv*`}, tu#7*{tu#7 <- `tu*`}) = !($subst_typevar(REC_typevar(n), tv#8*{tv#8 <- `tv*`}, tu#8*{tu#8 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*}(_IDX_typeuse(typeidx), tv#9*{tv#9 <- `tv*`}, tu#9*{tu#9 <- `tu*`}) = !($subst_typevar(_IDX_typevar(typeidx), tv#10*{tv#10 <- `tv*`}, tu#10*{tu#10 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:370.1-370.64 - def $subst_typeuse{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_typeuse(rectype, n), tv#11*{tv#11 <- `tv*`}, tu#11*{tu#11 <- `tu*`}) = $typeuse_deftype($subst_deftype(_DEF_deftype(rectype, n), tv#12*{tv#12 <- `tv*`}, tu#12*{tu#12 <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.1-343.112 -def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{n : n, `tv*` : typevar*, `tu*` : typeuse*}(REC_heaptype(n), tv#13*{tv#13 <- `tv*`}, tu#13*{tu#13 <- `tu*`}) = $heaptype_typeuse(!($subst_typevar(REC_typevar(n), tv#14*{tv#14 <- `tv*`}, tu#14*{tu#14 <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*}(_IDX_heaptype(typeidx), tv#15*{tv#15 <- `tv*`}, tu#15*{tu#15 <- `tu*`}) = $heaptype_typeuse(!($subst_typevar(_IDX_typevar(typeidx), tv#16*{tv#16 <- `tv*`}, tu#16*{tu#16 <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:377.1-377.65 - def $subst_heaptype{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_heaptype(rectype, n), tv#17*{tv#17 <- `tv*`}, tu#17*{tu#17 <- `tu*`}) = $heaptype_deftype($subst_deftype(_DEF_deftype(rectype, n), tv#18*{tv#18 <- `tv*`}, tu#18*{tu#18 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:378.1-378.53 - def $subst_heaptype{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(ht, tv#19*{tv#19 <- `tv*`}, tu#19*{tu#19 <- `tu*`}) = ht - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.1-344.112 -def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 - def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, $subst_heaptype(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 -def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I32_valtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}) = $valtype_numtype($subst_numtype(I32_numtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(I64_valtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}) = $valtype_numtype($subst_numtype(I64_numtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F32_valtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}) = $valtype_numtype($subst_numtype(F32_numtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(F64_valtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}) = $valtype_numtype($subst_numtype(F64_numtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(V128_valtype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}) = $valtype_vectype($subst_vectype(V128_vectype, tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_valtype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}) = $valtype_reftype($subst_reftype(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation fun_subst_typeuse: `%%%%`(typeuse, typevar*, typeuse*, typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_typeuse(n), tv#7*{tv#7 <- `tv*`}, tu#7*{tu#7 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#8*{tv#8 <- `tv*`}, tu#8*{tu#8 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_typeuse(typeidx), tv#9*{tv#9 <- `tv*`}, tu#9*{tu#9 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#10*{tv#10 <- `tv*`}, tu#10*{tu#10 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_typeuse(rectype, n), tv#11*{tv#11 <- `tv*`}, tu#11*{tu#11 <- `tu*`}, $typeuse_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#12*{tv#12 <- `tv*`}, tu#12*{tu#12 <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation fun_subst_heaptype: `%%%%`(heaptype, typevar*, typeuse*, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_heaptype(n), tv#13*{tv#13 <- `tv*`}, tu#13*{tu#13 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#14*{tv#14 <- `tv*`}, tu#14*{tu#14 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_heaptype(typeidx), tv#15*{tv#15 <- `tv*`}, tu#15*{tu#15 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#16*{tv#16 <- `tv*`}, tu#16*{tu#16 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_heaptype(rectype, n), tv#17*{tv#17 <- `tv*`}, tu#17*{tu#17 <- `tu*`}, $heaptype_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#18*{tv#18 <- `tv*`}, tu#18*{tu#18 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_3{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(ht, tv#19*{tv#19 <- `tv*`}, tu#19*{tu#19 <- `tu*`}, ht) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation fun_subst_reftype: `%%%%`(reftype, typevar*, typeuse*, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule fun_subst_reftype_case_0{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : heaptype}: + `%%%%`(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}, REF_reftype(null?{null <- `null?`}, var_0)) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_0{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I32_valtype, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, $valtype_numtype($subst_numtype(I32_numtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_1{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I64_valtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}, $valtype_numtype($subst_numtype(I64_numtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_2{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F32_valtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}, $valtype_numtype($subst_numtype(F32_numtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_3{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F64_valtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}, $valtype_numtype($subst_numtype(F64_numtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_4{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(V128_valtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}, $valtype_vectype($subst_vectype(V128_vectype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_5{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(REF_valtype(`null?`, heaptype), tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_6{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(BOT_valtype, tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}, BOT_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation fun_subst_storagetype: `%%%%`(storagetype, typevar*, typeuse*, storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_0{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(BOT_storagetype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_1{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(REF_storagetype(`null?`, heaptype), tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_2{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(V128_storagetype, tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_3{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F64_storagetype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_4{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F32_storagetype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_5{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I64_storagetype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_6{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I32_storagetype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_7{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I8_storagetype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}, $storagetype_packtype($subst_packtype(I8_packtype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_8{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I16_storagetype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}, $storagetype_packtype($subst_packtype(I16_packtype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation fun_subst_fieldtype: `%%%%`(fieldtype, typevar*, typeuse*, fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule fun_subst_fieldtype_case_0{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_0{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_1{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_2{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_1*` : valtype*, `var_0*` : valtype*}: + `%%%%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} + -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation fun_subst_subtype: `%%%%`(subtype, typevar*, typeuse*, subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule fun_subst_subtype_case_0{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) + -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 +relation fun_subst_rectype: `%%%%`(rectype, typevar*, typeuse*, rectype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 + rule fun_subst_rectype_case_0{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#4*{tu'#4 <- `tu'*`}) = !($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`})) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 +relation fun_subst_deftype: `%%%%`(deftype, typevar*, typeuse*, deftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 + rule fun_subst_deftype_case_0{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*, var_0 : rectype}: + `%%%%`(_DEF_deftype(qt, i), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, _DEF_deftype(var_0, i)) + -- fun_subst_rectype: `%%%%`(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) +} -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 -def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_storagetype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}) = $storagetype_valtype($subst_valtype(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_storagetype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}) = $storagetype_valtype($subst_valtype(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(V128_storagetype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}) = $storagetype_valtype($subst_valtype(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F64_storagetype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}) = $storagetype_valtype($subst_valtype(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(F32_storagetype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}) = $storagetype_valtype($subst_valtype(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I64_storagetype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}) = $storagetype_valtype($subst_valtype(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I32_storagetype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}) = $storagetype_valtype($subst_valtype(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I8_storagetype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}) = $storagetype_packtype($subst_packtype(I8_packtype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{`tv*` : typevar*, `tu*` : typeuse*}(I16_storagetype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}) = $storagetype_packtype($subst_packtype(I16_packtype, tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 -def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, $subst_storagetype(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 -def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`})*{ft#2 <- `ft*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`})*{t_1#2 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`})*{t_2#2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 -def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, $subst_typeuse(tu'#4, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`})*{tu'#4 <- `tu'*`}, $subst_comptype(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 -def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#5*{tu'#5 <- `tu'*`}) = !($minus_recs(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 -def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typeuse: `%%%%`(typeuse, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype, var_2 : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_heaptype: `%`(ret_val) + -- fun_subst_heaptype: `%%%%`(heaptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype, var_2 : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_reftype: `%`(ret_val) + -- fun_subst_reftype: `%%%%`(reftype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype, var_2 : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_valtype: `%`(ret_val) + -- fun_subst_valtype: `%%%%`(valtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype, var_2 : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_storagetype: `%`(ret_val) + -- fun_subst_storagetype: `%%%%`(storagetype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype, var_2 : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_fieldtype: `%`(ret_val) + -- fun_subst_fieldtype: `%%%%`(fieldtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype, var_2 : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_comptype: `%`(ret_val) + -- fun_subst_comptype: `%%%%`(comptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype, var_2 : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_subtype: `%`(ret_val) + -- fun_subst_subtype: `%%%%`(subtype, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}) = at + def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}) = at + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_tagtype: `%%%%`(tagtype, typevar*, typeuse*, tagtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_tagtype_case_0{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tagtype}: + `%%%%`(tu', tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype +relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#2?{mut#2 <- `mut?`}, t), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, $subst_valtype(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}))) + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype, var_2 : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_globaltype: `%`(ret_val) + -- fun_subst_globaltype: `%%%%`(globaltype, var_0, var_1, var_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#72*{tv#72 <- `tv*`}, tu#72*{tu#72 <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}) = `%%PAGE`_memtype(at, lim) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_tabletype: `%%%%`(tabletype, typevar*, typeuse*, tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}))) + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype, var_2 : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_tabletype: `%`(ret_val) + -- fun_subst_tabletype: `%%%%`(tabletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_externtype: `%%%%`(externtype, typevar*, typeuse*, externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_0{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(MEM_externtype(mt), tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}, MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_externtype_is_wf_0{externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype, var_2 : externtype}: + `%%%%`(externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_externtype: `%`(ret_val) + -- fun_subst_externtype: `%%%%`(externtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_moduletype_case_0{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_1*` : externtype*, `var_0*` : externtype*}: + `%%%%`(`%->%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%->%`_moduletype(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} + -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype, var_2 : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_moduletype: `%`(ret_val) + -- fun_subst_moduletype: `%%%%`(moduletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_all_valtype: `%%%`(valtype, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_all_valtype_case_0{t : valtype, n : nat, `tu*` : typeuse*, i : nat, var_0 : valtype}: + `%%%`(t, tu#71*{tu#71 <- `tu*`}, var_0) + -- if (n = |`tu*`|) + -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#85*{tv#85 <- `tv*`}, tu#85*{tu#85 <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`})*{xt_1#2 <- `xt_1*`}, $subst_externtype(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`})*{xt_2#2 <- `xt_2*`})) + rule fun_subst_all_globaltype_case_0{gt : globaltype, n : nat, `tu*` : typeuse*, i : nat, var_0 : globaltype}: + `%%%`(gt, tu#75*{tu#75 <- `tu*`}, var_0) + -- if (n = |`tu*`|) + -- fun_subst_globaltype: `%%%%`(gt, _IDX_typevar(`%`_typeidx(i))^(i%`_comptype(resulttype_1, resulttype_2), var_0 +++ var_1) + -- fun_free_resulttype: `%%`(resulttype_2, var_1) + -- fun_free_resulttype: `%%`(resulttype_1, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation fun_free_subtype: `%%`(subtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule fun_free_subtype_case_0{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(SUB_subtype(final#2?{final#2 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(comptype, var_2) + -- (fun_free_typeuse: `%%`(typeuse, var_1))*{var_1 <- `var_1*`, typeuse <- `typeuse*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation fun_free_rectype: `%%`(rectype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule fun_free_rectype_case_0{`subtype*` : subtype*, `var_1*` : free*, var_0 : free}: + `%%`(REC_rectype(`%`_list(subtype#5*{subtype#5 <- `subtype*`})), var_0) + -- (fun_free_subtype: `%%`(subtype, var_1))*{var_1 <- `var_1*`, subtype <- `subtype*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation fun_free_deftype: `%%`(deftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule fun_free_deftype_case_0{rectype : rectype, n : nat, var_0 : free}: + `%%`(_DEF_deftype(rectype, n), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) +} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.1-481.36 -def $free_heaptype(heaptype : heaptype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(ANY_heaptype) = $free_absheaptype(ANY_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(EQ_heaptype) = $free_absheaptype(EQ_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(I31_heaptype) = $free_absheaptype(I31_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(STRUCT_heaptype) = $free_absheaptype(STRUCT_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(ARRAY_heaptype) = $free_absheaptype(ARRAY_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(NONE_heaptype) = $free_absheaptype(NONE_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(FUNC_heaptype) = $free_absheaptype(FUNC_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(NOFUNC_heaptype) = $free_absheaptype(NOFUNC_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(EXN_heaptype) = $free_absheaptype(EXN_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(NOEXN_heaptype) = $free_absheaptype(NOEXN_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(EXTERN_heaptype) = $free_absheaptype(EXTERN_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(NOEXTERN_heaptype) = $free_absheaptype(NOEXTERN_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype(BOT_heaptype) = $free_absheaptype(BOT_absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:530.1-530.53 - def $free_heaptype{n_0 : n}(REC_heaptype(n_0)) = $free_typeuse(REC_typeuse(n_0)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:530.1-530.53 - def $free_heaptype{rectype : rectype, n : n}(_DEF_heaptype(rectype, n)) = $free_typeuse(_DEF_typeuse(rectype, n)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:530.1-530.53 - def $free_heaptype{typeidx : typeidx}(_IDX_heaptype(typeidx)) = $free_typeuse(_IDX_typeuse(typeidx)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.1-482.34 -def $free_reftype(reftype : reftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:532.1-532.65 - def $free_reftype{`null?` : null?, heaptype : heaptype}(REF_reftype(null#3?{null#3 <- `null?`}, heaptype)) = $free_heaptype(heaptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.1-484.34 -def $free_typeuse(typeuse : typeuse) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:526.1-526.52 - def $free_typeuse{n : n}(REC_typeuse(n)) = $free_typevar(REC_typevar(n)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:526.1-526.52 - def $free_typeuse{typeidx : typeidx}(_IDX_typeuse(typeidx)) = $free_typevar(_IDX_typevar(typeidx)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:527.1-527.52 - def $free_typeuse{rectype : rectype, n : n}(_DEF_typeuse(rectype, n)) = $free_deftype(_DEF_deftype(rectype, n)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.1-485.34 -def $free_valtype(valtype : valtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:534.1-534.52 - def $free_valtype(I32_valtype) = $free_numtype(I32_numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:534.1-534.52 - def $free_valtype(I64_valtype) = $free_numtype(I64_numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:534.1-534.52 - def $free_valtype(F32_valtype) = $free_numtype(F32_numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:534.1-534.52 - def $free_valtype(F64_valtype) = $free_numtype(F64_numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:535.1-535.52 - def $free_valtype(V128_valtype) = $free_vectype(V128_vectype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:536.1-536.52 - def $free_valtype{`null?` : null?, heaptype : heaptype}(REF_valtype(`null?`, heaptype)) = $free_reftype(REF_reftype(`null?`, heaptype)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:537.1-537.28 - def $free_valtype(BOT_valtype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.1-487.40 -def $free_resulttype(resulttype : resulttype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:539.1-539.69 - def $free_resulttype{`valtype*` : valtype*}(`%`_resulttype(valtype#503*{valtype#503 <- `valtype*`})) = $free_list($free_valtype(valtype)*{valtype <- `valtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.1-488.42 -def $free_storagetype(storagetype : storagetype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(BOT_storagetype) = $free_valtype(BOT_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype{`null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype)) = $free_valtype(REF_valtype(`null?`, heaptype)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(V128_storagetype) = $free_valtype(V128_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(F64_storagetype) = $free_valtype(F64_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(F32_storagetype) = $free_valtype(F32_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(I64_storagetype) = $free_valtype(I64_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype(I32_storagetype) = $free_valtype(I32_valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:542.1-542.59 - def $free_storagetype(I8_storagetype) = $free_packtype(I8_packtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:542.1-542.59 - def $free_storagetype(I16_storagetype) = $free_packtype(I16_packtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.1-489.38 -def $free_fieldtype(fieldtype : fieldtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:544.1-544.71 - def $free_fieldtype{`mut?` : mut?, storagetype : storagetype}(`%%`_fieldtype(mut#5?{mut#5 <- `mut?`}, storagetype)) = $free_storagetype(storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.1-490.36 -def $free_comptype(comptype : comptype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:546.1-546.80 - def $free_comptype{`fieldtype*` : fieldtype*}(STRUCT_comptype(`%`_list(fieldtype#1*{fieldtype#1 <- `fieldtype*`}))) = $free_list($free_fieldtype(fieldtype)*{fieldtype <- `fieldtype*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:547.1-547.65 - def $free_comptype{fieldtype : fieldtype}(ARRAY_comptype(fieldtype)) = $free_fieldtype(fieldtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:548.1-548.121 - def $free_comptype{resulttype_1 : list(syntax valtype), resulttype_2 : list(syntax valtype)}(`FUNC%->%`_comptype(resulttype_1, resulttype_2)) = $free_resulttype(resulttype_1) +++ $free_resulttype(resulttype_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.1-491.34 -def $free_subtype(subtype : subtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:550.1-551.66 - def $free_subtype{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype}(SUB_subtype(final#3?{final#3 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype)) = $free_list($free_typeuse(typeuse)*{typeuse <- `typeuse*`}) +++ $free_comptype(comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.1-492.34 -def $free_rectype(rectype : rectype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:553.1-553.70 - def $free_rectype{`subtype*` : subtype*}(REC_rectype(`%`_list(subtype#8*{subtype#8 <- `subtype*`}))) = $free_list($free_subtype(subtype)*{subtype <- `subtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.1-520.34 -def $free_deftype(deftype : deftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:521.1-521.59 - def $free_deftype{rectype : rectype, n : nat}(_DEF_deftype(rectype, n)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation free_heaptype_is_wf: `%%`(heaptype : heaptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule free_heaptype_is_wf_0{heaptype : heaptype, ret_val : free, var_0 : free}: + `%%`(heaptype, ret_val) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_heaptype: `%%`(heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation free_reftype_is_wf: `%%`(reftype : reftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule free_reftype_is_wf_0{reftype : reftype, ret_val : free, var_0 : free}: + `%%`(reftype, ret_val) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation free_typeuse_is_wf: `%%`(typeuse : typeuse, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule free_typeuse_is_wf_0{typeuse : typeuse, ret_val : free, var_0 : free}: + `%%`(typeuse, ret_val) + -- wf_typeuse: `%`(typeuse) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation free_valtype_is_wf: `%%`(valtype : valtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule free_valtype_is_wf_0{valtype : valtype, ret_val : free, var_0 : free}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_valtype: `%%`(valtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation free_resulttype_is_wf: `%%`(resulttype : resulttype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule free_resulttype_is_wf_0{resulttype : resulttype, ret_val : free, var_0 : free}: + `%%`(resulttype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_resulttype: `%%`(resulttype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation free_storagetype_is_wf: `%%`(storagetype : storagetype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule free_storagetype_is_wf_0{storagetype : storagetype, ret_val : free, var_0 : free}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_storagetype: `%%`(storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation free_fieldtype_is_wf: `%%`(fieldtype : fieldtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule free_fieldtype_is_wf_0{fieldtype : fieldtype, ret_val : free, var_0 : free}: + `%%`(fieldtype, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_fieldtype: `%%`(fieldtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation free_comptype_is_wf: `%%`(comptype : comptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule free_comptype_is_wf_0{comptype : comptype, ret_val : free, var_0 : free}: + `%%`(comptype, ret_val) + -- wf_comptype: `%`(comptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_comptype: `%%`(comptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation free_subtype_is_wf: `%%`(subtype : subtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule free_subtype_is_wf_0{subtype : subtype, ret_val : free, var_0 : free}: + `%%`(subtype, ret_val) + -- wf_subtype: `%`(subtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_subtype: `%%`(subtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation free_rectype_is_wf: `%%`(rectype : rectype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule free_rectype_is_wf_0{rectype : rectype, ret_val : free, var_0 : free}: + `%%`(rectype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_rectype: `%%`(rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation free_deftype_is_wf: `%%`(deftype : deftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule free_deftype_is_wf_0{deftype : deftype, ret_val : free, var_0 : free}: + `%%`(deftype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_deftype: `%%`(deftype, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tagtype(tagtype : tagtype) : free +relation fun_free_tagtype: `%%`(tagtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tagtype_case_0{rectype : rectype, n : n, var_0 : free}: + `%%`(_DEF_tagtype(rectype, n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(rectype, n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tagtype_is_wf: `%%`(tagtype : tagtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tagtype_is_wf_0{tagtype : tagtype, ret_val : free, var_0 : free}: + `%%`(tagtype, ret_val) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tagtype: `%%`(tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_globaltype: `%%`(globaltype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{rectype : rectype, n : n}(_DEF_tagtype(rectype, n)) = $free_deftype(_DEF_deftype(rectype, n)) + rule fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_globaltype(globaltype : globaltype) : free +relation free_globaltype_is_wf: `%%`(globaltype : globaltype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_globaltype{`mut?` : mut?, valtype : valtype}(`%%`_globaltype(mut#6?{mut#6 <- `mut?`}, valtype)) = $free_valtype(valtype) + rule free_globaltype_is_wf_0{globaltype : globaltype, ret_val : free, var_0 : free}: + `%%`(globaltype, ret_val) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_globaltype: `%%`(globaltype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_memtype(memtype : memtype) : free @@ -2242,38 +3327,116 @@ def $free_memtype(memtype : memtype) : free def $free_memtype{addrtype : addrtype, limits : limits}(`%%PAGE`_memtype(addrtype, limits)) = $free_addrtype(addrtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free +relation free_memtype_is_wf: `%%`(memtype : memtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_memtype_is_wf_0{memtype : memtype, ret_val : free}: + `%%`(memtype, ret_val) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $free_memtype(memtype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_tabletype: `%%`(tabletype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tabletype_case_0{addrtype : addrtype, limits : limits, reftype : reftype, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), $free_addrtype(addrtype) +++ var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tabletype_is_wf: `%%`(tabletype : tabletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tabletype{addrtype : addrtype, limits : limits, reftype : reftype}(`%%%`_tabletype(addrtype, limits, reftype)) = $free_addrtype(addrtype) +++ $free_reftype(reftype) + rule free_tabletype_is_wf_0{tabletype : tabletype, ret_val : free, var_0 : free}: + `%%`(tabletype, ret_val) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tabletype: `%%`(tabletype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(datatype : datatype) : free ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(OK_datatype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_elemtype(elemtype : elemtype) : free +relation free_datatype_is_wf: `%%`(datatype : datatype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_datatype_is_wf_0{datatype : datatype, ret_val : free}: + `%%`(datatype, ret_val) + -- if (ret_val = $free_datatype(datatype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_elemtype: `%%`(elemtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_elemtype_case_0{reftype : reftype, var_0 : free}: + `%%`(reftype, var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_elemtype_is_wf: `%%`(elemtype : elemtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) + rule free_elemtype_is_wf_0{elemtype : elemtype, ret_val : free, var_0 : free}: + `%%`(elemtype, ret_val) + -- wf_reftype: `%`(elemtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemtype: `%%`(elemtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_externtype(externtype : externtype) : free +relation fun_free_externtype: `%%`(externtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_externtype(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_1{globaltype : globaltype, var_0 : free}: + `%%`(GLOBAL_externtype(globaltype), var_0) + -- fun_free_globaltype: `%%`(globaltype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tagtype : typeuse}(TAG_externtype(tagtype)) = $free_tagtype(tagtype) + rule fun_free_externtype_case_2{memtype : memtype}: + `%%`(MEM_externtype(memtype), $free_memtype(memtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) + rule fun_free_externtype_case_3{tabletype : tabletype, var_0 : free}: + `%%`(TABLE_externtype(tabletype), var_0) + -- fun_free_tabletype: `%%`(tabletype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) + rule fun_free_externtype_case_4{typeuse : typeuse, var_0 : free}: + `%%`(FUNC_externtype(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_externtype_is_wf: `%%`(externtype : externtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) + rule free_externtype_is_wf_0{externtype : externtype, ret_val : free, var_0 : free}: + `%%`(externtype, ret_val) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_moduletype: `%%`(moduletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) + rule fun_free_moduletype_case_0{`externtype_1*` : externtype*, `externtype_2*` : externtype*, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(`%->%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`}), var_0 +++ var_2) + -- (fun_free_externtype: `%%`(externtype_2, var_3))*{var_3 <- `var_3*`, externtype_2 <- `externtype_2*`} + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_externtype: `%%`(externtype_1, var_1))*{var_1 <- `var_1*`, externtype_1 <- `externtype_1*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_moduletype(moduletype : moduletype) : free +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_moduletype{`externtype_1*` : externtype*, `externtype_2*` : externtype*}(`%->%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free, var_0 : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_moduletype: `%%`(moduletype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = @@ -2791,7 +3954,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -4505,7 +5676,6 @@ relation wf_instr: `%`(instr) `%`(VEXTRACT_LANE_instr(shape, `sx?`, laneidx)) -- wf_shape: `%`(shape) -- wf_uN: `%%`(8, laneidx) - -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 @@ -4578,25 +5748,36 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) - -- wf_instr: `%`(CONST_instr(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) - -- wf_instr: `%`(CONST_instr(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) - -- wf_instr: `%`(CONST_instr(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_consttype(consttype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free @@ -4604,11 +5785,34 @@ def $free_shape(shape : shape) : free def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_free_blocktype: `%%`(blocktype, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_0{`valtype?` : valtype?, `var_0?` : free?}: + `%%`(_RESULT_blocktype(valtype#504?{valtype#504 <- `valtype?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_0))?{var_0 <- `var_0?`, valtype <- `valtype?`} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_1{typeidx : uN}: + `%%`(_IDX_blocktype(typeidx), $free_typeidx(typeidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free, var_0 : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_blocktype: `%%`(blocktype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free @@ -4621,258 +5825,533 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 +relation fun_shift_labelidxs: `%%`(labelidx*, labelidx*) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_1{`labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}, var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_2{labelidx : uN, `labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}, [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.1-584.44 -def $shift_labelidxs(labelidx*) : labelidx* - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:585.1-585.32 - def $shift_labelidxs([]) = [] - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:586.1-586.66 - def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 - def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}) = [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation fun_free_instr: `%%`(instr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_0: + `%%`(NOP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_1: + `%%`(UNREACHABLE_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_2: + `%%`(DROP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{`valtype*?` : valtype*?, `var_1*?` : free*?, `var_0?` : free?}: + `%%`(SELECT_instr(valtype#505*{valtype#505 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `valtype*`}?{`var_1*` <- `var_1*?`, `valtype*` <- `valtype*?`} + -- (fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0))?{`var_1*` <- `var_1*?`, var_0 <- `var_0?`} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_4{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_5{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(LOOP_instr(blocktype, instr#2*{instr#2 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_6{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(`IF%%ELSE%`_instr(blocktype, instr_1#1*{instr_1#1 <- `instr_1*`}, instr_2#1*{instr_2#1 <- `instr_2*`}), var_0 +++ var_1 +++ var_2) + -- fun_free_block: `%%`(instr_2*{instr_2 <- `instr_2*`}, var_2) + -- fun_free_block: `%%`(instr_1*{instr_1 <- `instr_1*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_7{labelidx : uN}: + `%%`(BR_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN}: + `%%`(BR_IF_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ $free_labelidx(labelidx')) + -- fun_free_list: `%%`($free_labelidx(labelidx)*{labelidx <- `labelidx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN}: + `%%`(BR_ON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN}: + `%%`(BR_ON_NON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_12{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_13{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN}: + `%%`(CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_15{typeuse : typeuse, var_0 : free}: + `%%`(CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_16{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_17: + `%%`(RETURN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{funcidx : uN}: + `%%`(RETURN_CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_19{typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_20{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN}: + `%%`(THROW_instr(tagidx), $free_tagidx(tagidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_22: + `%%`(THROW_REF_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_23{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*, `var_3*` : free*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`}), var_0 +++ var_1 +++ var_2) + -- (fun_free_instr: `%%`(instr, var_3))*{var_3 <- `var_3*`, instr <- `instr*`} + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- fun_free_list: `%%`($free_catch(catch)*{catch <- `catch*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_24{numtype : numtype, numlit : num_}: + `%%`(CONST_instr(numtype, numlit), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_}: + `%%`(UNOP_instr(numtype, unop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_}: + `%%`(BINOP_instr(numtype, binop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_}: + `%%`(TESTOP_instr(numtype, testop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_}: + `%%`(RELOP_instr(numtype, relop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_29{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), $free_numtype(numtype_1) +++ $free_numtype(numtype_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN}: + `%%`(VCONST_instr(vectype, veclit), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop}: + `%%`(VVUNOP_instr(vectype, vvunop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop}: + `%%`(VVBINOP_instr(vectype, vvbinop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop}: + `%%`(VVTERNOP_instr(vectype, vvternop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop}: + `%%`(VVTESTOP_instr(vectype, vvtestop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_}: + `%%`(VUNOP_instr(shape, vunop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_}: + `%%`(VBINOP_instr(shape, vbinop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_}: + `%%`(VTERNOP_instr(shape, vternop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_}: + `%%`(VTESTOP_instr(shape, vtestop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_}: + `%%`(VRELOP_instr(shape, vrelop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape}: + `%%`(VBITMASK_instr(ishape), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_44{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_45{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_46{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_47{ishape_1 : ishape, ishape_2 : ishape, sx : sx}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_48{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), $free_shape(shape_1) +++ $free_shape(shape_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape}: + `%%`(VSPLAT_instr(shape), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_50{shape : shape, `sx?` : sx?, laneidx : uN}: + `%%`(VEXTRACT_LANE_instr(shape, sx#45969?{sx#45969 <- `sx?`}, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_52{heaptype : heaptype, var_0 : free}: + `%%`(`REF.NULL`_instr(heaptype), var_0) + -- fun_free_heaptype: `%%`(heaptype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_53: + `%%`(`REF.IS_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_54: + `%%`(`REF.AS_NON_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_55: + `%%`(`REF.EQ`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_56{reftype : reftype, var_0 : free}: + `%%`(`REF.TEST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_57{reftype : reftype, var_0 : free}: + `%%`(`REF.CAST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_58{funcidx : uN}: + `%%`(`REF.FUNC`_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_59: + `%%`(`REF.I31`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_60{sx : sx}: + `%%`(`I31.GET`_instr(sx), {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{typeidx : uN}: + `%%`(`STRUCT.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_63{`sx?` : sx?, typeidx : uN, u32 : uN}: + `%%`(`STRUCT.GET`_instr(sx#45970?{sx#45970 <- `sx?`}, typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN}: + `%%`(`ARRAY.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN}: + `%%`(`ARRAY.GET`_instr(sx#45971?{sx#45971 <- `sx?`}, typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN}: + `%%`(`ARRAY.SET`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_72: + `%%`(`ARRAY.LEN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{typeidx : uN}: + `%%`(`ARRAY.FILL`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_74{typeidx_1 : uN, typeidx_2 : uN}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_77: + `%%`(`EXTERN.CONVERT_ANY`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_78: + `%%`(`ANY.CONVERT_EXTERN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{localidx : uN}: + `%%`(`LOCAL.GET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN}: + `%%`(`LOCAL.SET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN}: + `%%`(`LOCAL.TEE`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN}: + `%%`(`GLOBAL.GET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN}: + `%%`(`GLOBAL.SET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN}: + `%%`(`TABLE.GET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN}: + `%%`(`TABLE.SET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN}: + `%%`(`TABLE.SIZE`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN}: + `%%`(`TABLE.GROW`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN}: + `%%`(`TABLE.FILL`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_89{tableidx_1 : uN, tableidx_2 : uN}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), $free_tableidx(tableidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN}: + `%%`(`ELEM.DROP`_instr(elemidx), $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_92{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_93{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_94{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_95{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_96{vectype : vectype, memidx : uN, memarg : memarg}: + `%%`(VSTORE_instr(vectype, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_97{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN}: + `%%`(`MEMORY.SIZE`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN}: + `%%`(`MEMORY.GROW`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN}: + `%%`(`MEMORY.FILL`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_101{memidx_1 : uN, memidx_2 : uN}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), $free_memidx(memidx_1) +++ $free_memidx(memidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), $free_memidx(memidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN}: + `%%`(`DATA.DROP`_instr(dataidx), $free_dataidx(dataidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation fun_free_block: `%%`(instr*, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule fun_free_block_case_0{`instr*` : instr*, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- let{free : free} free = var_1 + -- (fun_free_instr: `%%`(instr#5, var_2))*{var_2 <- `var_2*`, instr#5 <- `instr*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_shift_labelidxs: `%%`(free.LABELS_free, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.1-420.30 -def $free_instr(instr : instr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 - def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 - def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 - def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(LOOP_instr(blocktype, instr#2*{instr#2 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:442.1-443.79 - def $free_instr{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}(`IF%%ELSE%`_instr(blocktype, instr_1#1*{instr_1#1 <- `instr_1*`}, instr_2#1*{instr_2#1 <- `instr_2*`})) = $free_blocktype(blocktype) +++ $free_block(instr_1*{instr_1 <- `instr_1*`}) +++ $free_block(instr_2*{instr_2 <- `instr_2*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:445.1-445.56 - def $free_instr{labelidx : uN}(BR_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:446.1-446.59 - def $free_instr{labelidx : uN}(BR_IF_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:447.1-448.69 - def $free_instr{`labelidx*` : labelidx*, labelidx' : uN}(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx')) = $free_list($free_labelidx(labelidx)*{labelidx <- `labelidx*`}) +++ $free_labelidx(labelidx') - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:449.1-449.64 - def $free_instr{labelidx : uN}(BR_ON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:450.1-450.68 - def $free_instr{labelidx : uN}(BR_ON_NON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:451.1-452.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:453.1-454.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:456.1-456.55 - def $free_instr{funcidx : uN}(CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:457.1-457.59 - def $free_instr{typeuse : typeuse}(CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:458.1-459.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 - def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 - def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 - def $free_instr{typeuse : typeuse}(RETURN_CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:463.1-464.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(RETURN_CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:466.1-466.53 - def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 - def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 - def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 - def $free_instr{numtype : numtype, numlit : num_}(CONST_instr(numtype, numlit)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:472.1-472.60 - def $free_instr{numtype : numtype, unop : unop_}(UNOP_instr(numtype, unop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:473.1-473.62 - def $free_instr{numtype : numtype, binop : binop_}(BINOP_instr(numtype, binop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:474.1-474.64 - def $free_instr{numtype : numtype, testop : testop_}(TESTOP_instr(numtype, testop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:475.1-475.62 - def $free_instr{numtype : numtype, relop : relop_}(RELOP_instr(numtype, relop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:476.1-477.55 - def $free_instr{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}(CVTOP_instr(numtype_1, numtype_2, cvtop)) = $free_numtype(numtype_1) +++ $free_numtype(numtype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:479.1-479.64 - def $free_instr{vectype : vectype, veclit : uN}(VCONST_instr(vectype, veclit)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:480.1-480.64 - def $free_instr{vectype : vectype, vvunop : vvunop}(VVUNOP_instr(vectype, vvunop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:481.1-481.66 - def $free_instr{vectype : vectype, vvbinop : vvbinop}(VVBINOP_instr(vectype, vvbinop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:482.1-482.68 - def $free_instr{vectype : vectype, vvternop : vvternop}(VVTERNOP_instr(vectype, vvternop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:483.1-483.68 - def $free_instr{vectype : vectype, vvtestop : vvtestop}(VVTESTOP_instr(vectype, vvtestop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:484.1-484.56 - def $free_instr{shape : shape, vunop : vunop_}(VUNOP_instr(shape, vunop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:485.1-485.58 - def $free_instr{shape : shape, vbinop : vbinop_}(VBINOP_instr(shape, vbinop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:486.1-486.60 - def $free_instr{shape : shape, vternop : vternop_}(VTERNOP_instr(shape, vternop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:487.1-487.60 - def $free_instr{shape : shape, vtestop : vtestop_}(VTESTOP_instr(shape, vtestop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:488.1-488.58 - def $free_instr{shape : shape, vrelop : vrelop_}(VRELOP_instr(shape, vrelop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:489.1-489.64 - def $free_instr{ishape : ishape, vshiftop : vshiftop_}(VSHIFTOP_instr(ishape, vshiftop)) = $free_shape($proj_ishape_0(ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:490.1-490.55 - def $free_instr{ishape : ishape}(VBITMASK_instr(ishape)) = $free_shape($proj_ishape_0(ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:491.1-491.66 - def $free_instr{bshape : bshape, vswizzlop : vswizzlop_}(VSWIZZLOP_instr(bshape, vswizzlop)) = $free_shape($proj_bshape_0(bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:492.1-492.64 - def $free_instr{bshape : bshape, `laneidx*` : laneidx*}(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`})) = $free_shape($proj_bshape_0(bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:493.1-494.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}(VEXTUNOP_instr(ishape_1, ishape_2, vextunop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:495.1-496.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:497.1-498.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:499.1-500.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, sx : sx}(VNARROW_instr(ishape_1, ishape_2, sx)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:501.1-502.47 - def $free_instr{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}(VCVTOP_instr(shape_1, shape_2, vcvtop)) = $free_shape(shape_1) +++ $free_shape(shape_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:503.1-503.51 - def $free_instr{shape : shape}(VSPLAT_instr(shape)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:504.1-504.70 - def $free_instr{shape : shape, `sx?` : sx?, laneidx : uN}(VEXTRACT_LANE_instr(shape, sx#45969?{sx#45969 <- `sx?`}, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:505.1-505.66 - def $free_instr{shape : shape, laneidx : uN}(VREPLACE_LANE_instr(shape, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:507.1-507.62 - def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 - def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 - def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 - def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 - def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 - def $free_instr{reftype : reftype}(`REF.CAST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:513.1-513.59 - def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 - def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 - def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 - def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 - def $free_instr{typeidx : uN}(`STRUCT.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:520.1-520.69 - def $free_instr{`sx?` : sx?, typeidx : uN, u32 : uN}(`STRUCT.GET`_instr(sx#45970?{sx#45970 <- `sx?`}, typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:521.1-521.65 - def $free_instr{typeidx : uN, u32 : uN}(`STRUCT.SET`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:523.1-523.60 - def $free_instr{typeidx : uN}(`ARRAY.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:524.1-524.68 - def $free_instr{typeidx : uN}(`ARRAY.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:525.1-525.70 - def $free_instr{typeidx : uN, u32 : uN}(`ARRAY.NEW_FIXED`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:526.1-527.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.NEW_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:528.1-529.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:530.1-530.64 - def $free_instr{`sx?` : sx?, typeidx : uN}(`ARRAY.GET`_instr(sx#45971?{sx#45971 <- `sx?`}, typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:531.1-531.60 - def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 - def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 - def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 - def $free_instr{typeidx_1 : uN, typeidx_2 : uN}(`ARRAY.COPY`_instr(typeidx_1, typeidx_2)) = $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:536.1-537.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.INIT_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:538.1-539.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 - def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 - def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 - def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 - def $free_instr{localidx : uN}(`LOCAL.SET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:546.1-546.63 - def $free_instr{localidx : uN}(`LOCAL.TEE`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:548.1-548.67 - def $free_instr{globalidx : uN}(`GLOBAL.GET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:549.1-549.67 - def $free_instr{globalidx : uN}(`GLOBAL.SET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:551.1-551.63 - def $free_instr{tableidx : uN}(`TABLE.GET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:552.1-552.63 - def $free_instr{tableidx : uN}(`TABLE.SET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:553.1-553.64 - def $free_instr{tableidx : uN}(`TABLE.SIZE`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:554.1-554.64 - def $free_instr{tableidx : uN}(`TABLE.GROW`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:555.1-555.64 - def $free_instr{tableidx : uN}(`TABLE.FILL`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:556.1-557.59 - def $free_instr{tableidx_1 : uN, tableidx_2 : uN}(`TABLE.COPY`_instr(tableidx_1, tableidx_2)) = $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:558.1-559.53 - def $free_instr{tableidx : uN, elemidx : uN}(`TABLE.INIT`_instr(tableidx, elemidx)) = $free_tableidx(tableidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:560.1-560.60 - def $free_instr{elemidx : uN}(`ELEM.DROP`_instr(elemidx)) = $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:562.1-563.49 - def $free_instr{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:564.1-565.49 - def $free_instr{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:566.1-567.49 - def $free_instr{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:568.1-569.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:570.1-571.49 - def $free_instr{vectype : vectype, memidx : uN, memarg : memarg}(VSTORE_instr(vectype, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:572.1-573.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:574.1-574.59 - def $free_instr{memidx : uN}(`MEMORY.SIZE`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:575.1-575.59 - def $free_instr{memidx : uN}(`MEMORY.GROW`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:576.1-576.59 - def $free_instr{memidx : uN}(`MEMORY.FILL`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:577.1-578.51 - def $free_instr{memidx_1 : uN, memidx_2 : uN}(`MEMORY.COPY`_instr(memidx_1, memidx_2)) = $free_memidx(memidx_1) +++ $free_memidx(memidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:579.1-580.49 - def $free_instr{memidx : uN, dataidx : uN}(`MEMORY.INIT`_instr(memidx, dataidx)) = $free_memidx(memidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:581.1-581.60 - def $free_instr{dataidx : uN}(`DATA.DROP`_instr(dataidx)) = $free_dataidx(dataidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.1-421.31 -def $free_block(instr*) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:589.1-590.47 - def $free_block{`instr*` : instr*}(instr#4*{instr#4 <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] - -- let{free : free} free = $free_list($free_instr(instr#5)*{instr#5 <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free, var_0 : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_instr: `%%`(instr, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_block: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_expr(expr : expr) : free +relation fun_free_expr: `%%`(expr, free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_expr{`instr*` : instr*}(instr#6*{instr#6 <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) + rule fun_free_expr_case_0{`instr*` : instr*, `var_1*` : free*, var_0 : free}: + `%%`(instr#6*{instr#6 <- `instr*`}, var_0) + -- (fun_free_instr: `%%`(instr, var_1))*{var_1 <- `var_1*`, instr <- `instr*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_expr_is_wf_0{expr : expr, ret_val : free, var_0 : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_expr: `%%`(expr, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = @@ -5060,19 +6539,55 @@ relation wf_module: `%`(module) -- (wf_start: `%`(start))?{start <- `start?`} ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_type(type : type) : free +relation fun_free_type: `%%`(type, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) + rule fun_free_type_case_0{rectype : rectype, var_0 : free}: + `%%`(TYPE_type(rectype), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_tag(tag : tag) : free +relation free_type_is_wf: `%%`(type : type, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) + rule free_type_is_wf_0{type : type, ret_val : free, var_0 : free}: + `%%`(type, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_type: `%%`(type, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_global(global : global) : free +relation fun_free_tag: `%%`(tag, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) + rule fun_free_tag_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_tag(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_tag_is_wf_0{tag : tag, ret_val : free, var_0 : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tag: `%%`(tag, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_global: `%%`(global, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_global_case_0{globaltype : globaltype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(GLOBAL_global(globaltype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_globaltype: `%%`(globaltype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free, var_0 : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_global: `%%`(global, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free @@ -5080,48 +6595,150 @@ def $free_mem(mem : mem) : free def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_table: `%%`(table, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_table_case_0{tabletype : tabletype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(TABLE_table(tabletype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tabletype: `%%`(tabletype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free, var_0 : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_table: `%%`(table, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_local: `%%`(local, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_local_case_0{t : valtype, var_0 : free}: + `%%`(LOCAL_local(t), var_0) + -- fun_free_valtype: `%%`(t, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_local_is_wf_0{local : local, ret_val : free, var_0 : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_local: `%%`(local, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_func: `%%`(func, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) + rule fun_free_func_case_0{typeidx : uN, `local*` : local*, expr : instr*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), $free_typeidx(typeidx) +++ var_0 +++ var_2[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_2) + -- (fun_free_local: `%%`(local, var_1))*{var_1 <- `var_1*`, local <- `local*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_local(local : local) : free +relation free_func_is_wf: `%%`(func : func, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + rule free_func_is_wf_0{func : func, ret_val : free, var_0 : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_func: `%%`(func, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_func(func : func) : free +relation fun_free_datamode: `%%`(datamode, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] + rule fun_free_datamode_case_0{memidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), $free_memidx(memidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_datamode_case_1: + `%%`(PASSIVE_datamode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free, var_0 : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_datamode: `%%`(datamode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_data: `%%`(data, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_data_case_0{`byte*` : byte*, datamode : datamode, var_0 : free}: + `%%`(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode), var_0) + -- fun_free_datamode: `%%`(datamode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(data : data) : free +relation free_data_is_wf: `%%`(data : data, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode)) = $free_datamode(datamode) + rule free_data_is_wf_0{data : data, ret_val : free, var_0 : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_data: `%%`(data, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elemmode(elemmode : elemmode) : free +relation fun_free_elemmode: `%%`(elemmode, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_0{tableidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), $free_tableidx(tableidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_1: + `%%`(PASSIVE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) + rule fun_free_elemmode_case_2: + `%%`(DECLARE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free, var_0 : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemmode: `%%`(elemmode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_elem: `%%`(elem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_elem_case_0{reftype : reftype, `expr*` : expr*, elemmode : elemmode, var_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode), var_0 +++ var_1 +++ var_3) + -- fun_free_elemmode: `%%`(elemmode, var_3) + -- (fun_free_expr: `%%`(expr, var_2))*{var_2 <- `var_2*`, expr <- `expr*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_reftype: `%%`(reftype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elem(elem : elem) : free +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) + rule free_elem_is_wf_0{elem : elem, ret_val : free, var_0 : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elem: `%%`(elem, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free @@ -5129,9 +6746,30 @@ def $free_start(start : start) : free def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_import: `%%`(import, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_import_case_0{name_1 : name, name_2 : name, externtype : externtype, var_0 : free}: + `%%`(IMPORT_import(name_1, name_2, externtype), var_0) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) + rule free_import_is_wf_0{import : import, ret_val : free, var_0 : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_import: `%%`(import, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free @@ -5139,19 +6777,62 @@ def $free_export(export : export) : free def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_module: `%%`(module, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_module_case_0{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_17 : free, `var_16*` : free*, var_15 : free, `var_14*` : free*, var_13 : free, `var_12*` : free*, var_11 : free, `var_10*` : free*, var_9 : free, `var_8*` : free*, var_7 : free, var_6 : free, `var_5*` : free*, var_4 : free, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`})), var_0 +++ var_2 +++ var_4 +++ var_6 +++ var_7 +++ var_9 +++ var_11 +++ var_13 +++ $free_opt($free_start(start)?{start <- `start?`}) +++ var_15 +++ var_17) + -- fun_free_list: `%%`($free_export(export)*{export <- `export*`}, var_17) + -- (fun_free_import: `%%`(import, var_16))*{var_16 <- `var_16*`, import <- `import*`} + -- fun_free_list: `%%`(var_16*{var_16 <- `var_16*`}, var_15) + -- (fun_free_elem: `%%`(elem, var_14))*{var_14 <- `var_14*`, elem <- `elem*`} + -- fun_free_list: `%%`(var_14*{var_14 <- `var_14*`}, var_13) + -- (fun_free_data: `%%`(data, var_12))*{var_12 <- `var_12*`, data <- `data*`} + -- fun_free_list: `%%`(var_12*{var_12 <- `var_12*`}, var_11) + -- (fun_free_func: `%%`(func, var_10))*{var_10 <- `var_10*`, func <- `func*`} + -- fun_free_list: `%%`(var_10*{var_10 <- `var_10*`}, var_9) + -- (fun_free_table: `%%`(table, var_8))*{var_8 <- `var_8*`, table <- `table*`} + -- fun_free_list: `%%`(var_8*{var_8 <- `var_8*`}, var_7) + -- fun_free_list: `%%`($free_mem(mem)*{mem <- `mem*`}, var_6) + -- (fun_free_global: `%%`(global, var_5))*{var_5 <- `var_5*`, global <- `global*`} + -- fun_free_list: `%%`(var_5*{var_5 <- `var_5*`}, var_4) + -- (fun_free_tag: `%%`(tag, var_3))*{var_3 <- `var_3*`, tag <- `tag*`} + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_type: `%%`(type, var_1))*{var_1 <- `var_1*`, type <- `type*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) + rule free_module_is_wf_0{module : module, ret_val : free, var_0 : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_module: `%%`(module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $funcidx_module(module : module) : funcidx* +relation fun_funcidx_module: `%%`(module, funcidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $funcidx_module{module : module}(module) = $free_module(module).FUNCS_free + rule fun_funcidx_module_case_0{module : module, var_0 : free}: + `%%`(module, var_0.FUNCS_free) + -- fun_free_module: `%%`(module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $dataidx_funcs(func*) : dataidx* +relation fun_dataidx_funcs: `%%`(func*, dataidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $dataidx_funcs{`func*` : func*}(func#2*{func#2 <- `func*`}) = $free_list($free_func(func)*{func <- `func*`}).DATAS_free + rule fun_dataidx_funcs_case_0{`func*` : func*, `var_1*` : free*, var_0 : free}: + `%%`(func#2*{func#2 <- `func*`}, var_0.DATAS_free) + -- (fun_free_func: `%%`(func, var_1))*{var_1 <- `var_1*`, func <- `func*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax init = @@ -5212,60 +6893,146 @@ relation wf_context: `%`(context) -- (wf_uN: `%%`(32, var_11))*{var_11 <- var_11} -- (wf_subtype: `%`(var_12))*{var_12 <- var_12} +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_with_locals_before_fun_with_locals_case_2: `%%%`(context, localidx*, localtype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_0{C : context}: + `%%%`(C, [], []) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.1-49.158 -def $with_locals(context : context, localidx*, localtype*) : context? - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:51.1-51.34 - def $with_locals{C : context}(C, [], []) = ?(C) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:52.1-52.90 - def $with_locals{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*}(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}) = $with_locals(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}) - def $with_locals{x0 : context, x1 : localidx*, x2 : localtype*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation fun_with_locals: `%%%%`(context, localidx*, localtype*, context?) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_0{C : context}: + `%%%%`(C, [], [], ?(C)) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}, var_0) + -- fun_with_locals: `%%%%`(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}, var_0) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_2{x0 : context, x1 : localidx*, x2 : localtype*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_with_locals_before_fun_with_locals_case_2: `%%%`(x0, x1, x2) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 -def $clos_deftypes(deftype*) : deftype* - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 - def $clos_deftypes([]) = [] - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:72.1-72.101 - def $clos_deftypes{`dt*` : deftype*, dt_n : deftype}(dt#2*{dt#2 <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`})] - -- let{`dt'*` : deftype*} dt'#1*{dt'#1 <- `dt'*`} = $clos_deftypes(dt#3*{dt#3 <- `dt*`}) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context, var_2 : context?}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- wf_context: `%`(ret_val) + -- fun_with_locals: `%%%%`(context, var_0, var_1, var_2) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 +relation fun_clos_deftypes: `%%`(deftype*, deftype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- let{`dt'*` : deftype*} dt'#1*{dt'#1 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_valtype(context : context, valtype : valtype) : valtype +relation fun_clos_valtype: `%%%`(context, valtype, valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_valtype_case_0{C : context, t : valtype, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_clos_valtype: `%%%`(context, valtype, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_deftype: `%%%`(context, deftype, deftype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_deftype_case_0{C : context, dt : deftype, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- let{`dt'*` : deftype*} dt'#2*{dt'#2 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- let{`dt*` : deftype*} dt#5*{dt#5 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype}(C, dt) = $subst_all_deftype(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}) - -- let{`dt'*` : deftype*} dt'#2*{dt'#2 <- `dt'*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_externtype_case_0{C : context, xt : externtype, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse}(C, jt) = $subst_all_tagtype(jt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt#5*{dt#5 <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype, var_0 : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_externtype: `%`(ret_val) + -- fun_clos_externtype: `%%%`(context, externtype, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype, var_0 : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_moduletype: `%`(ret_val) + -- fun_clos_moduletype: `%%%`(context, moduletype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -5309,10 +7076,12 @@ relation Numtype_sub: `%|-%<:%`(context, numtype, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Expand: `%~~%`(deftype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: + rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*, var_0 : subtype}: `%~~%`(deftype, comptype) - -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- fun_unrolldt: `%%`(deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5329,13 +7098,31 @@ def $before(typeuse : typeuse, nat : nat) : bool def $before{typeuse : typeuse, i : nat}(typeuse, i) = true ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $unrollht_(context : context, heaptype : heaptype) : subtype +relation fun_unrollht_: `%%%`(context, heaptype, subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule fun_unrollht__case_0{rectype : rectype, n : n, C : context, var_0 : subtype}: + `%%%`(C, _DEF_heaptype(rectype, n), var_0) + -- fun_unrolldt: `%%`(_DEF_deftype(rectype, n), var_0) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{rectype : rectype, n : n, C : context}(C, _DEF_heaptype(rectype, n)) = $unrolldt(_DEF_deftype(rectype, n)) + rule fun_unrollht__case_1{C : context, typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(typeidx), var_0) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(typeidx).0], var_0) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, typeidx : uN}(C, _IDX_heaptype(typeidx)) = $unrolldt(C.TYPES_context[$proj_uN_0(typeidx).0]) + rule fun_unrollht__case_2{C : context, i : nat}: + `%%%`(C, REC_heaptype(i), C.RECS_context[i]) + +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype, var_0 : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_subtype: `%`(ret_val) + -- fun_unrollht_: `%%%`(context, heaptype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5401,7 +7188,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5409,7 +7195,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) -- wf_context: `%`(C) -- wf_subtype: `%`(st) @@ -5481,19 +7266,19 @@ relation Comptype_ok: `%|-%:OK`(context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:97.1-97.126 relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:167.1-176.49 - rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**}: + rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- if (|`comptype'*`| = |`typeuse*`|) - -- if (|`comptype'*`| = |`typeuse'**`|) - -- (if ($unrollht_(C, $heaptype_typeuse(typeuse)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} + -- (if (var_0 = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- (fun_unrollht_: `%%%`(C, $heaptype_typeuse(typeuse), var_0))*{var_0 <- `var_0*`, typeuse <- `typeuse*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) @@ -5521,13 +7306,13 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) -- if (i < n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- if (n = |`subtype*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} -- wf_context: `%`(C) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) @@ -5553,19 +7338,22 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:103.1-103.107 relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:195.1-197.66 - rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype}: + rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype, var_1 : deftype, var_0 : deftype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) -- wf_context: `%`(C) + -- fun_clos_deftype: `%%%`(C, deftype_2, var_1) + -- fun_clos_deftype: `%%%`(C, deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:199.1-202.49 - rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: + rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat, var_0 : subtype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |typeuse*{typeuse <- `typeuse*`}|) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[i]), $heaptype_deftype(deftype_2)) -- wf_context: `%`(C) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- fun_unrolldt: `%%`(deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) @@ -5647,7 +7435,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5656,7 +7443,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0])) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) @@ -5665,7 +7451,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5675,7 +7460,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5685,7 +7469,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5695,8 +7478,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: `%|-%<:%`(C, REC_heaptype(i), $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[j])) - -- if (j < |typeuse*{typeuse <- `typeuse*`}|) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5805,7 +7586,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`t_1*`| = |`t_2*`|) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} @@ -5863,8 +7643,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`lct*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- `lct*`} @@ -5882,7 +7660,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) @@ -5902,20 +7679,19 @@ relation wf_oktypeidx: `%`(oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**}: + rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- if (|`comptype'*`| = |`yy**`|) - -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} - -- (if ($unrolldt(C.TYPES_context[$proj_uN_0(x).0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} + -- (if (var_0 = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `yy*` <- `yy**`} -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- (fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(x).0], var_0))*{var_0 <- `var_0*`, x <- `x*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -6036,11 +7812,10 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) - -- if (|`t*`| = |`x*`|) - -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -6169,7 +7944,6 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) @@ -6181,10 +7955,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) @@ -6193,10 +7964,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) @@ -6205,7 +7973,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) @@ -6213,7 +7980,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) @@ -6222,35 +7988,38 @@ relation Catch_ok: `%|-%:OK`(context, catch) def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F32_valtype) = ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F64_valtype) = ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%DEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6352,7 +8121,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6363,7 +8131,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, `t*` : valtype*}: `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) @@ -6372,9 +8139,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]))*{l <- `l*`} - -- if ($proj_uN_0(l').0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l').0]) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6384,7 +8149,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) @@ -6394,7 +8158,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -6403,7 +8166,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6417,7 +8179,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) @@ -6425,13 +8186,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) @@ -6441,7 +8202,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) @@ -6451,10 +8211,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) @@ -6476,7 +8234,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6491,7 +8248,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6506,10 +8262,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) @@ -6526,8 +8280,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) @@ -6568,9 +8320,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule `ref.func`{C : context, x : idx, dt : deftype}: `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) - -- if (|C.REFS_context| > 0) -- if (x <- C.REFS_context) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) @@ -6636,7 +8386,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) @@ -6646,10 +8395,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6657,9 +8406,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6671,9 +8418,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) @@ -6684,7 +8429,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) @@ -6694,10 +8438,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6705,7 +8449,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) @@ -6715,9 +8458,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) @@ -6727,12 +8468,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6740,7 +8480,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) @@ -6751,7 +8490,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule `array.set`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) @@ -6768,7 +8506,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule `array.fill`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) @@ -6778,9 +8515,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) @@ -6792,9 +8527,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), zt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) @@ -6804,12 +8537,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6833,7 +8565,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule `local.get`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) @@ -6843,7 +8574,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule `local.set`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) @@ -6853,7 +8583,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule `local.tee`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) @@ -6863,7 +8592,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -6873,7 +8601,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule `global.set`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) @@ -6883,7 +8610,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GET`_instr(x)) @@ -6893,7 +8619,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -6903,7 +8628,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) @@ -6913,7 +8637,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GROW`_instr(x)) @@ -6923,7 +8646,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) @@ -6933,9 +8655,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6947,9 +8667,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) @@ -6961,7 +8679,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule `elem.drop`{C : context, x : idx, rt : reftype}: `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) @@ -6971,7 +8688,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) @@ -6981,7 +8697,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) @@ -6991,7 +8706,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) @@ -7001,9 +8715,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) @@ -7014,9 +8726,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) @@ -7026,7 +8736,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule `data.drop`{C : context, x : idx}: `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) @@ -7035,7 +8744,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -7046,7 +8754,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -7057,7 +8764,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) @@ -7068,7 +8774,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) @@ -7079,7 +8784,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -7090,7 +8794,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) -- wf_context: `%`(C) @@ -7101,7 +8804,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -7112,7 +8814,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) @@ -7123,7 +8824,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -7135,7 +8835,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) @@ -7146,7 +8845,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -7293,6 +8991,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) @@ -7308,6 +9007,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) @@ -7316,6 +9016,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) @@ -7363,23 +9064,21 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:617.1-621.82 - rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) - -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- Instrs_ok: `%|-%:%`(!(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 rule sub{C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -7418,9 +9117,9 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7499,7 +9198,6 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule `global.get`{C : context, x : idx, t : valtype}: `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -7508,9 +9206,7 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, Inn : Inn, binop : binop_}: `%|-%CONST`(C, BINOP_instr($numtype_addrtype(Inn), binop)) - -- if (|[I32_Inn I64_Inn]| > 0) -- if (Inn <- [I32_Inn I64_Inn]) - -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr($numtype_addrtype(Inn), binop)) @@ -7541,23 +9237,26 @@ relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Type_ok: `%|-%:%`(context, type, deftype*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx}: + rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx, var_0 : deftype*}: `%|-%:%`(C, TYPE_type(rectype), dt*{dt <- `dt*`}) -- if ($proj_uN_0(x).0 = |C.TYPES_context|) - -- if (dt*{dt <- `dt*`} = $rolldt(x, rectype)) + -- if (dt*{dt <- `dt*`} = var_0) -- Rectype_ok: `%|-%:%`(C +++ {TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rectype, OK_oktypeidx(x)) -- wf_context: `%`(C) -- wf_context: `%`({TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_oktypeidx: `%`(OK_oktypeidx(x)) + -- fun_rolldt: `%%%`(x, rectype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Tag_ok: `%|-%:%`(context, tag, tagtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, tagtype : tagtype}: - `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) + rule _{C : context, tagtype : tagtype, var_0 : tagtype}: + `%|-%:%`(C, TAG_tag(tagtype), var_0) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`(var_0) -- wf_tag: `%`(TAG_tag(tagtype)) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7615,9 +9314,7 @@ relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[$proj_uN_0(x).0]) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`lct*`| = |`local*`|) -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- wf_context: `%`(C) @@ -7636,7 +9333,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) @@ -7671,7 +9367,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) @@ -7696,7 +9391,6 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) @@ -7705,18 +9399,19 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Import_ok: `%|-%:%`(context, import, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, name_1 : name, name_2 : name, xt : externtype}: - `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) + rule _{C : context, name_1 : name, name_2 : name, xt : externtype, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`(var_0) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) @@ -7725,7 +9420,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) @@ -7734,7 +9428,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) @@ -7743,7 +9436,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) @@ -7752,7 +9444,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) @@ -7826,48 +9517,46 @@ relation wf_nonfuncs: `%`(nonfuncs) -- (wf_export: `%`(export))*{export <- `export*`} ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* +relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#3*{export#3 <- `export*`}))) + rule fun_funcidx_nonfuncs_case_0{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_0 : funcidx*}: + `%%`(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`}), var_0) + -- fun_funcidx_module: `%%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: - `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*, var_6 : deftype*, var_5 : tabletype*, var_4 : memtype*, var_3 : globaltype*, var_2 : tagtype*, var_1 : funcidx*, var_0 : moduletype}: + `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) - -- if (|`import*`| = |`xt_I*`|) -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} - -- if (|`jt*`| = |`tag*`|) -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- if (|`mem*`| = |`mt*`|) -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} - -- if (|`table*`| = |`tt*`|) -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} - -- if (|`dt*`| = |`func*`|) -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} - -- if (|`data*`| = |`ok*`|) -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} - -- if (|`elem*`| = |`rt*`|) -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} - -- if (|`export*`| = |`nm*`|) - -- if (|`export*`| = |`xt_E*`|) -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- if (C' = {TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) - -- if (x*{x <- `x*`} = $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))) - -- if (jt_I*{jt_I <- `jt_I*`} = $tagsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (gt_I*{gt_I <- `gt_I*`} = $globalsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (mt_I*{mt_I <- `mt_I*`} = $memsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (tt_I*{tt_I <- `tt_I*`} = $tablesxt(xt_I*{xt_I <- `xt_I*`})) - -- if (dt_I*{dt_I <- `dt_I*`} = $funcsxt(xt_I*{xt_I <- `xt_I*`})) + -- if (x*{x <- `x*`} = var_1) + -- if (jt_I*{jt_I <- `jt_I*`} = var_2) + -- if (gt_I*{gt_I <- `gt_I*`} = var_3) + -- if (mt_I*{mt_I <- `mt_I*`} = var_4) + -- if (tt_I*{tt_I <- `tt_I*`} = var_5) + -- if (dt_I*{dt_I <- `dt_I*`} = var_6) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`(var_0) + -- (wf_uN: `%%`(32, iter))*{iter <- var_1} + -- (wf_typeuse: `%`(iter))*{iter <- var_2} + -- (wf_globaltype: `%`(iter))*{iter <- var_3} + -- (wf_memtype: `%`(iter))*{iter <- var_4} + -- (wf_tabletype: `%`(iter))*{iter <- var_5} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7875,6 +9564,13 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`({TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) -- wf_nonfuncs: `%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) + -- fun_funcsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_6) + -- fun_tablesxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_5) + -- fun_memsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_4) + -- fun_globalsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_3) + -- fun_tagsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_2) + -- fun_funcidx_nonfuncs: `%%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}), var_1) + -- fun_clos_moduletype: `%%%`(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}), var_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed2 = @@ -7921,97 +9617,294 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_signed_: `%%%`(N, nat, int) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = (i : nat <:> int) + rule fun_signed__case_0{N : nat, i : nat}: + `%%%`(N, i, (i : nat <:> int)) -- if (i < (2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = ((i : nat <:> int) - ((2 ^ N) : nat <:> int)) + rule fun_signed__case_1{N : nat, i : nat}: + `%%%`(N, i, ((i : nat <:> int) - ((2 ^ N) : nat <:> int))) -- if (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) <= i) /\ (i < (2 ^ N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_signed_(N : N, int : int) : nat +relation fun_inv_signed_: `%%%`(N, int, nat) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = (i : int <:> nat) + rule fun_inv_signed__case_0{N : nat, i : int}: + `%%%`(N, i, (i : int <:> nat)) -- if (((0 : nat <:> int) <= i) /\ (i < ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = ((i + ((2 ^ N) : nat <:> int)) : int <:> nat) + rule fun_inv_signed__case_1{N : nat, i : int}: + `%%%`(N, i, ((i + ((2 ^ N) : nat <:> int)) : int <:> nat)) -- if ((- ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= i) /\ (i < (0 : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -8037,22 +9930,24 @@ def $sx(storagetype : storagetype) : sx?? def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, `%`_uN(0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F32_lanetype) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(F64_lanetype) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -8081,12 +9976,12 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iabs_{N : nat, i_1 : uN}(N, i_1) = (if ($signed_(N, $proj_uN_0(i_1).0) >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + def $iabs_{N : nat, i_1 : uN, var_0 : int}(N, i_1) = (if (var_0 >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iclz_(N : N, iN : iN) : iN @@ -8098,61 +9993,81 @@ def $ictz_(N : N, iN : iN) : iN def $ipopcnt_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN +relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ M)))) + rule fun_iextend__case_0{N : nat, M : nat, i : uN}: + `%%%%%`(N, M, U_sx, i, `%`_iN(($proj_uN_0(i).0 \ (2 ^ M)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M)))))) + rule fun_iextend__case_1{N : nat, M : nat, i : uN, var_1 : int, var_0 : nat}: + `%%%%%`(N, M, S_sx, i, `%`_iN(var_0)) + -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) + -- fun_inv_signed_: `%%%`(N, var_1, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) + rule fun_idiv__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?() - -- if ((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + rule fun_idiv__case_3{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}: + `%%%%%`(N, S_sx, i_1, i_2, ?()) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) + rule fun_idiv__case_4{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $truncz(((var_1 : int <:> rat) / (var_2 : int <:> rat))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) + rule fun_irem__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -- if ((j_1 = $signed_(N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) + rule fun_irem__case_3{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat))))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8163,7 +10078,9 @@ def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imin_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 <= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8174,25 +10091,29 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imax_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 >= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0)))))) + def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 + var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0)))))) + def $isub_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 - var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8243,116 +10164,285 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0))))) + def $ilt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 < var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0))))) + def $igt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 > var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0))))) + def $ile_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 <= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0))))) + def $ige_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 >= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsqrt_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fceil_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ffloor_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ftrunc_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fnearest_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fadd_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsub_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmul_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fdiv_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $feq_(N : N, fN : fN, fN : fN) : u32 @@ -8374,9 +10464,31 @@ def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -8395,38 +10507,77 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I32_numtype), mk_lane__0_lane_(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I64_numtype), mk_lane__0_lane_(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F32_numtype), mk_lane__0_lane_(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F64_numtype), mk_lane__0_lane_(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I8_packtype), mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I16_packtype), mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8442,10 +10593,18 @@ def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I8_packtype), mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I16_packtype), mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), lit_) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ @@ -8459,10 +10618,17 @@ def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I8_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I16_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ @@ -8478,196 +10644,291 @@ def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ def $cunpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I8_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I16_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule fun_unop__case_0{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_1{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_2{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule fun_unop__case_3{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_4{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule fun_unop__case_5{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_6{M : nat, i : uN, var_0 : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{M : nat, i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i))) + rule fun_unop__case_7{M : nat, i : uN, var_0 : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{M : nat, i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i))) + rule fun_unop__case_8{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#1)*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#1)))*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_9{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#3)))*{iter_0#3 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_10{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#3)*{iter_0#3 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#6)*{iter_0#6 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#5)))*{iter_0#5 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_11{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#7)))*{iter_0#7 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_12{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#5)*{iter_0#5 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#10)*{iter_0#10 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#9)))*{iter_0#9 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_13{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#6)*{iter_0#6 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#11)))*{iter_0#11 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_14{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#7)*{iter_0#7 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#14)*{iter_0#14 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#13)))*{iter_0#13 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_15{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#16)*{iter_0#16 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#15)))*{iter_0#15 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_16{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#9)*{iter_0#9 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#18)*{iter_0#18 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#17)))*{iter_0#17 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_17{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#10)*{iter_0#10 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#19)))*{iter_0#19 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_18{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#11)*{iter_0#11 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#22)*{iter_0#22 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#21)))*{iter_0#21 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_19{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#23)))*{iter_0#23 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_20{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#13)*{iter_0#13 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#26)*{iter_0#26 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#25)))*{iter_0#25 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_21{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#14)*{iter_0#14 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#27)))*{iter_0#27 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_unop_: `%%%%`(numtype, unop_, num_, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* +relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_0{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_1{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_2{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_3{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_4{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_5{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_6{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#15)*{iter_0#15 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#30)*{iter_0#30 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} + rule fun_binop__case_7{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#16)*{iter_0#16 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#32)*{iter_0#32 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} + rule fun_binop__case_8{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#17)*{iter_0#17 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2))} + rule fun_binop__case_9{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#18)*{iter_0#18 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2))} + rule fun_binop__case_10{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_11{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_12{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_13{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_14{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_15{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_16{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_17{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_18{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_19{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_20{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_21{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_22{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_23{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_24{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#19)*{iter_0#19 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#38)*{iter_0#38 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#37)))*{iter_0#37 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_25{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#40)*{iter_0#40 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#39)))*{iter_0#39 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_26{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#21)*{iter_0#21 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#41)))*{iter_0#41 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_27{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#22)*{iter_0#22 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#43)))*{iter_0#43 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_28{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#23)*{iter_0#23 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#45)))*{iter_0#45 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_29{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#47)))*{iter_0#47 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_30{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#25)*{iter_0#25 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#50)*{iter_0#50 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49)))*{iter_0#49 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_31{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#26)*{iter_0#26 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#52)*{iter_0#52 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51)))*{iter_0#51 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_32{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#27)*{iter_0#27 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#54)*{iter_0#54 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#53)))*{iter_0#53 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_33{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#56)*{iter_0#56 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#55)))*{iter_0#55 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_34{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#29)*{iter_0#29 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#58)*{iter_0#58 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#57)))*{iter_0#57 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_35{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#30)*{iter_0#30 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#60)*{iter_0#60 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#59)))*{iter_0#59 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_36{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#31)*{iter_0#31 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#62)*{iter_0#62 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61)))*{iter_0#61 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_37{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#32)*{iter_0#32 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#64)*{iter_0#64 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63)))*{iter_0#63 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_binop_: `%%%%%`(numtype, binop_, num_, num__0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 @@ -8728,327 +10989,765 @@ def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* +relation fun_cvtop__: `%%%%%`(numtype, numtype, cvtop__, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))) + rule fun_cvtop___case_0{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))) + rule fun_cvtop___case_1{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))) + rule fun_cvtop___case_2{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))) + rule fun_cvtop___case_3{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) + rule fun_cvtop___case_4{i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) + rule fun_cvtop___case_5{i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) + rule fun_cvtop___case_6{i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) + rule fun_cvtop___case_7{i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#66)*{iter_0#66 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#65)))*{iter_0#65 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + rule fun_cvtop___case_8{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#33)*{iter_0#33 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#68)*{iter_0#68 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#67)))*{iter_0#67 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + rule fun_cvtop___case_9{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#70)*{iter_0#70 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#69)))*{iter_0#69 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + rule fun_cvtop___case_10{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#35)*{iter_0#35 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#72)*{iter_0#72 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#71)))*{iter_0#71 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + rule fun_cvtop___case_11{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#74)*{iter_0#74 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#73)))*{iter_0#73 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + rule fun_cvtop___case_12{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#37)*{iter_0#37 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#76)*{iter_0#76 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#75)))*{iter_0#75 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))} + rule fun_cvtop___case_13{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#38)*{iter_0#38 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#78)*{iter_0#78 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#77)))*{iter_0#77 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + rule fun_cvtop___case_14{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#39)*{iter_0#39 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#80)*{iter_0#80 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#79)))*{iter_0#79 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))} + rule fun_cvtop___case_15{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#40)*{iter_0#40 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))) + rule fun_cvtop___case_16{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))) + rule fun_cvtop___case_17{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))) + rule fun_cvtop___case_18{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{sx : sx, i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))) + rule fun_cvtop___case_19{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#82)*{iter_0#82 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#81)))*{iter_0#81 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_20{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#41)*{iter_0#41 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#84)*{iter_0#84 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#83)))*{iter_0#83 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_21{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#86)*{iter_0#86 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#85)))*{iter_0#85 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_22{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#43)*{iter_0#43 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#88)*{iter_0#88 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#87)))*{iter_0#87 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_23{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#90)*{iter_0#90 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#89)))*{iter_0#89 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_24{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#45)*{iter_0#45 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#92)*{iter_0#92 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#91)))*{iter_0#91 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_25{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#94)*{iter_0#94 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#93)))*{iter_0#93 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_26{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#47)*{iter_0#47 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#96)*{iter_0#96 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#95)))*{iter_0#95 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_27{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))] + rule fun_cvtop___case_28{i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))]) -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))] + rule fun_cvtop___case_29{i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))]) -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))] + rule fun_cvtop___case_30{i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))]) -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))] + rule fun_cvtop___case_31{i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))]) -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))] + rule fun_cvtop___case_32{f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))]) -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))] + rule fun_cvtop___case_33{f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))]) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))] + rule fun_cvtop___case_34{f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))]) -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))] + rule fun_cvtop___case_35{f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))]) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} + -- fun_cvtop__: `%%%%%`(numtype_1, numtype_2, cvtop__, num_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? +relation fun_zeroop: `%%%%`(shape, shape, vcvtop__, zero?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`}))) = zero#3442?{zero#3442 <- `zero?`} + rule fun_zeroop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`})), zero#3442?{zero#3442 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`}))) = zero#3444?{zero#3444 <- `zero?`} + rule fun_zeroop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`})), zero#3444?{zero#3444 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`}))) = zero#3446?{zero#3446 <- `zero?`} + rule fun_zeroop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`})), zero#3446?{zero#3446 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`}))) = zero#3448?{zero#3448 <- `zero?`} + rule fun_zeroop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`})), zero#3448?{zero#3448 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`}))) = zero#3450?{zero#3450 <- `zero?`} + rule fun_zeroop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`})), zero#3450?{zero#3450 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`}))) = zero#3452?{zero#3452 <- `zero?`} + rule fun_zeroop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`})), zero#3452?{zero#3452 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`}))) = zero#3454?{zero#3454 <- `zero?`} + rule fun_zeroop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`})), zero#3454?{zero#3454 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`}))) = zero#3456?{zero#3456 <- `zero?`} + rule fun_zeroop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`})), zero#3456?{zero#3456 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`}))) = zero#3458?{zero#3458 <- `zero?`} + rule fun_zeroop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`})), zero#3458?{zero#3458 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`}))) = zero#3460?{zero#3460 <- `zero?`} + rule fun_zeroop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`})), zero#3460?{zero#3460 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`}))) = zero#3462?{zero#3462 <- `zero?`} + rule fun_zeroop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`})), zero#3462?{zero#3462 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`}))) = zero#3464?{zero#3464 <- `zero?`} + rule fun_zeroop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`})), zero#3464?{zero#3464 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`}))) = zero#3466?{zero#3466 <- `zero?`} + rule fun_zeroop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`})), zero#3466?{zero#3466 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`}))) = zero#3468?{zero#3468 <- `zero?`} + rule fun_zeroop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`})), zero#3468?{zero#3468 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`}))) = zero#3470?{zero#3470 <- `zero?`} + rule fun_zeroop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`})), zero#3470?{zero#3470 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`}))) = zero#3472?{zero#3472 <- `zero?`} + rule fun_zeroop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`})), zero#3472?{zero#3472 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + rule fun_zeroop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + rule fun_zeroop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + rule fun_zeroop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + rule fun_zeroop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? +relation fun_halfop: `%%%%`(shape, shape, vcvtop__, half?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half : half, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_halfop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx))) = half#3046?{half#3046 <- `half?`} + rule fun_halfop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx)), half#3046?{half#3046 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx))) = half#3048?{half#3048 <- `half?`} + rule fun_halfop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx)), half#3048?{half#3048 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx))) = half#3050?{half#3050 <- `half?`} + rule fun_halfop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx)), half#3050?{half#3050 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx))) = half#3052?{half#3052 <- `half?`} + rule fun_halfop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx)), half#3052?{half#3052 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx))) = half#3054?{half#3054 <- `half?`} + rule fun_halfop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx)), half#3054?{half#3054 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx))) = half#3056?{half#3056 <- `half?`} + rule fun_halfop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx)), half#3056?{half#3056 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx))) = half#3058?{half#3058 <- `half?`} + rule fun_halfop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx)), half#3058?{half#3058 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx))) = half#3060?{half#3060 <- `half?`} + rule fun_halfop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx)), half#3060?{half#3060 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`}))) = ?() + rule fun_halfop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`}))) = ?() + rule fun_halfop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`}))) = ?() + rule fun_halfop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`}))) = ?() + rule fun_halfop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`}))) = ?() + rule fun_halfop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`}))) = ?() + rule fun_halfop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`}))) = ?() + rule fun_halfop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`}))) = ?() + rule fun_halfop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`}))) = ?() + rule fun_halfop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`}))) = ?() + rule fun_halfop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`}))) = ?() + rule fun_halfop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`}))) = ?() + rule fun_halfop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`}))) = ?() + rule fun_halfop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`}))) = ?() + rule fun_halfop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`}))) = ?() + rule fun_halfop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`}))) = ?() + rule fun_halfop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + rule fun_halfop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + rule fun_halfop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + rule fun_halfop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + rule fun_halfop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $half(half : half, nat : nat, nat : nat) : nat @@ -9061,398 +11760,368 @@ def $half(half : half, nat : nat, nat : nat) : nat def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#1*{c#1 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if ($signed_(N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) + def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN, var_0 : int}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if (var_0 < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#5)*{c#5 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#4)*{c#4 <- `c*`})] -- let{`c_1*` : lane_*} c_1#1*{c_1#1 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c*` : iN*} c#3*{c#3 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#2)))*{c_1#2 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#4)))*{c#4 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#8)*{c#8 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#6)*{c#6 <- `c*`})] -- let{`c_1*` : lane_*} c_1#3*{c_1#3 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#6*{c#6 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} + -- let{`c*` : iN*} c#5*{c#5 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#7)))*{c#7 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#11)*{c#11 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#8)*{c#8 <- `c*`})] -- let{`c_1*` : lane_*} c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} + -- let{`c*` : iN*} c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#10)))*{c#10 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#14)*{c#14 <- `c*`})] + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#10)*{c#10 <- `c*`})] -- let{`c_1*` : lane_*} c_1#7*{c_1#7 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#12*{c#12 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} + -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#13)))*{c#13 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#16*{c#16 <- `c*#2`})*{`c*#2` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#12*{c#12 <- `c*#2`})*{`c*#2` <- `c**`} -- let{`c_1*` : lane_*} c_1#9*{c_1#9 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#15*{c#15 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#97))*{iter_0#97 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) + -- let{`c**` : lane_**} c#11*{c#11 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49))*{iter_0#49 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#98))))*{iter_0#98 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#50))))*{iter_0#50 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#18*{c#18 <- `c*#4`})*{`c*#4` <- `c**`} + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#14*{c#14 <- `c*#4`})*{`c*#4` <- `c**`} -- let{`c_1*` : lane_*} c_1#12*{c_1#12 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#17*{c#17 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#99))*{iter_0#99 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) + -- let{`c**` : lane_**} c#13*{c#13 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51))*{iter_0#51 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#100))))*{iter_0#100 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#52))))*{iter_0#52 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#21)*{c#21 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#16)*{c#16 <- `c*`})] -- let{`c_1*` : lane_*} c_1#15*{c_1#15 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#1*{c_2#1 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} + -- let{`c*` : iN*} c#15*{c#15 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#20)))*{c#20 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#24)*{c#24 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#18)*{c#18 <- `c*`})] -- let{`c_1*` : lane_*} c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#3*{c_2#3 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#22*{c#22 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} + -- let{`c*` : iN*} c#17*{c#17 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#23)))*{c#23 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#27)*{c#27 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#20)*{c#20 <- `c*`})] -- let{`c_1*` : lane_*} c_1#19*{c_1#19 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} + -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#26)))*{c#26 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#22)*{c#22 <- `c*`})] -- let{`c_1*` : lane_*} c_1#21*{c_1#21 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#7*{c_2#7 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#28*{c#28 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} + -- let{`c*` : iN*} c#21*{c#21 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#29)))*{c#29 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#33)*{c#33 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#24)*{c#24 <- `c*`})] -- let{`c_1*` : lane_*} c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#9*{c_2#9 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#31*{c#31 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} + -- let{`c*` : iN*} c#23*{c#23 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#32)))*{c#32 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#36)*{c#36 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#26)*{c#26 <- `c*`})] -- let{`c_1*` : lane_*} c_1#25*{c_1#25 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#34*{c#34 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} + -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#35)))*{c#35 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#39)*{c#39 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#28)*{c#28 <- `c*`})] -- let{`c_1*` : lane_*} c_1#27*{c_1#27 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#13*{c_2#13 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#37*{c#37 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} + -- let{`c*` : iN*} c#27*{c#27 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#38)))*{c#38 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#42)*{c#42 <- `c*`})] + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] -- let{`c_1*` : lane_*} c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#15*{c_2#15 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#40*{c#40 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} + -- let{`c*` : iN*} c#29*{c#29 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#41)))*{c#41 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#6`})*{`c*#6` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#32*{c#32 <- `c*#6`})*{`c*#6` <- `c**`} -- let{`c_1*` : lane_*} c_1#31*{c_1#31 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#43*{c#43 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#101)*{iter_0#101 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) + -- let{`c**` : lane_**} c#31*{c#31 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#53)*{iter_0#53 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#102)))*{iter_0#102 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#54)))*{iter_0#54 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#8`})*{`c*#8` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#34*{c#34 <- `c*#8`})*{`c*#8` <- `c**`} -- let{`c_1*` : lane_*} c_1#34*{c_1#34 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#45*{c#45 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#103)*{iter_0#103 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) + -- let{`c**` : lane_**} c#33*{c#33 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#55)*{iter_0#55 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#104)))*{iter_0#104 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#56)))*{iter_0#56 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#10`})*{`c*#10` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#36*{c#36 <- `c*#10`})*{`c*#10` <- `c**`} -- let{`c_1*` : lane_*} c_1#37*{c_1#37 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#47*{c#47 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#105)*{iter_0#105 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) + -- let{`c**` : lane_**} c#35*{c#35 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#57)*{iter_0#57 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#106)))*{iter_0#106 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#58)))*{iter_0#58 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#12`})*{`c*#12` <- `c**`} + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#38*{c#38 <- `c*#12`})*{`c*#12` <- `c**`} -- let{`c_1*` : lane_*} c_1#40*{c_1#40 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#49*{c#49 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#107)*{iter_0#107 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) + -- let{`c**` : lane_**} c#37*{c#37 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#59)*{iter_0#59 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#108)))*{iter_0#108 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#60)))*{iter_0#60 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#14`})*{`c*#14` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#40*{c#40 <- `c*#14`})*{`c*#14` <- `c**`} -- let{`c_1*` : lane_*} c_1#43*{c_1#43 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#51*{c#51 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#109))*{iter_0#109 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) + -- let{`c**` : lane_**} c#39*{c#39 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61))*{iter_0#61 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#110))))*{iter_0#110 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#62))))*{iter_0#62 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#16`})*{`c*#16` <- `c**`} + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#42*{c#42 <- `c*#16`})*{`c*#16` <- `c**`} -- let{`c_1*` : lane_*} c_1#46*{c_1#46 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c#53*{c#53 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#111))*{iter_0#111 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) + -- let{`c**` : lane_**} c#41*{c#41 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63))*{iter_0#63 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#112))))*{iter_0#112 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#64))))*{iter_0#64 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#56*{c#56 <- `c*#18`})*{`c*#18` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#18`})*{`c*#18` <- `c**`} -- let{`c_1*` : lane_*} c_1#49*{c_1#49 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#1*{c_3#1 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#55*{c#55 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#113)*{iter_0#113 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) + -- let{`c**` : lane_**} c#43*{c#43 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#65)*{iter_0#65 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#114)))*{iter_0#114 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#66)))*{iter_0#66 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#58*{c#58 <- `c*#20`})*{`c*#20` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#20`})*{`c*#20` <- `c**`} -- let{`c_1*` : lane_*} c_1#52*{c_1#52 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#4*{c_3#4 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#57*{c#57 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#115)*{iter_0#115 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) + -- let{`c**` : lane_**} c#45*{c#45 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#67)*{iter_0#67 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#116)))*{iter_0#116 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#68)))*{iter_0#68 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#60*{c#60 <- `c*#22`})*{`c*#22` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#22`})*{`c*#22` <- `c**`} -- let{`c_1*` : lane_*} c_1#55*{c_1#55 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#7*{c_3#7 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#59*{c#59 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#117)*{iter_0#117 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) + -- let{`c**` : lane_**} c#47*{c#47 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#69)*{iter_0#69 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#118)))*{iter_0#118 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#70)))*{iter_0#70 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#62*{c#62 <- `c*#24`})*{`c*#24` <- `c**`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#24`})*{`c*#24` <- `c**`} -- let{`c_1*` : lane_*} c_1#58*{c_1#58 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#10*{c_3#10 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#61*{c#61 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#119)*{iter_0#119 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) + -- let{`c**` : lane_**} c#49*{c#49 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#71)*{iter_0#71 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#120)))*{iter_0#120 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#72)))*{iter_0#72 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#64*{c#64 <- `c*#26`})*{`c*#26` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#26`})*{`c*#26` <- `c**`} -- let{`c_1*` : lane_*} c_1#61*{c_1#61 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#13*{c_3#13 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#63*{c#63 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#121))*{iter_0#121 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) + -- let{`c**` : lane_**} c#51*{c#51 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#73))*{iter_0#73 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#122))))*{iter_0#122 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#74))))*{iter_0#74 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#66*{c#66 <- `c*#28`})*{`c*#28` <- `c**`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#28`})*{`c*#28` <- `c**`} -- let{`c_1*` : lane_*} c_1#64*{c_1#64 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) -- let{`c_3*` : lane_*} c_3#16*{c_3#16 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c#65*{c#65 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#123))*{iter_0#123 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) + -- let{`c**` : lane_**} c#53*{c#53 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#75))*{iter_0#75 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#124))))*{iter_0#124 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#76))))*{iter_0#76 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#69)*{c#69 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#56)*{c#56 <- `c*`}) -- let{`c_1*` : lane_*} c_1#67*{c_1#67 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} + -- let{`c*` : iN*} c#55*{c#55 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#68)))*{c#68 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- `c_1*`, c_2#55 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#72)*{c#72 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#58)*{c#58 <- `c*`}) -- let{`c_1*` : lane_*} c_1#70*{c_1#70 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#70*{c#70 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} + -- let{`c*` : iN*} c#57*{c#57 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#71)))*{c#71 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- `c_1*`, c_2#58 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#75)*{c#75 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#60)*{c#60 <- `c*`}) -- let{`c_1*` : lane_*} c_1#73*{c_1#73 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} + -- let{`c*` : iN*} c#59*{c#59 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#74)))*{c#74 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- `c_1*`, c_2#61 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#78)*{c#78 <- `c*`}) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#62)*{c#62 <- `c*`}) -- let{`c_1*` : lane_*} c_1#76*{c_1#76 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#76*{c#76 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} + -- let{`c*` : iN*} c#61*{c#61 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#77)))*{c#77 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- `c_1*`, c_2#64 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#81)*{c#81 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#64)*{c#64 <- `c*`}) -- let{`c_1*` : lane_*} c_1#79*{c_1#79 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} + -- let{`c*` : iN*} c#63*{c#63 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#80)))*{c#80 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- `c_1*`, c_2#67 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#84)*{c#84 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#66)*{c#66 <- `c*`}) -- let{`c_1*` : lane_*} c_1#82*{c_1#82 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#82*{c#82 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} + -- let{`c*` : iN*} c#65*{c#65 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#83)))*{c#83 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- `c_1*`, c_2#70 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#87)*{c#87 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#68)*{c#68 <- `c*`}) -- let{`c_1*` : lane_*} c_1#85*{c_1#85 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} + -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#86)))*{c#86 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- `c_1*`, c_2#73 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#70)*{c#70 <- `c*`}) -- let{`c_1*` : lane_*} c_1#88*{c_1#88 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#88*{c#88 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} + -- let{`c*` : iN*} c#69*{c#69 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#89)))*{c#89 <- `c*`} -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- `c_1*`, c_2#76 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#93).0)))*{c#93 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#72).0)))*{c#72 <- `c*`}) -- let{`c_1*` : lane_*} c_1#91*{c_1#91 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} + -- let{`c*` : iN*} c#71*{c#71 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} -- if ($isize(Inn) = $fsize(F32_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#92).0)))))*{c#92 <- `c*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- `c_1*`, c_2#79 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#96).0)))*{c#96 <- `c*`}) + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#74).0)))*{c#74 <- `c*`}) -- let{`c_1*` : lane_*} c_1#94*{c_1#94 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#94*{c#94 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} + -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} -- if ($isize(Inn) = $fsize(F64_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M))), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#95).0)))))*{c#95 <- `c*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- `c_1*`, c_2#82 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#99)*{c#99 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#76)*{c#76 <- `c*`}) -- let{`c_1*` : lane_*} c_1#97*{c_1#97 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} + -- let{`c*` : iN*} c#75*{c#75 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#98)))*{c#98 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#102)*{c#102 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#78)*{c#78 <- `c*`}) -- let{`c_1*` : lane_*} c_1#99*{c_1#99 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#100*{c#100 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} + -- let{`c*` : iN*} c#77*{c#77 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#101)))*{c#101 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#105)*{c#105 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#80)*{c#80 <- `c*`}) -- let{`c_1*` : lane_*} c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#103*{c#103 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} + -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#104)))*{c#104 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#108)*{c#108 <- `c*`}) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#82)*{c#82 <- `c*`}) -- let{`c_1*` : lane_*} c_1#103*{c_1#103 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#106*{c#106 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} + -- let{`c*` : iN*} c#81*{c#81 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#107)))*{c#107 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#111)*{c#111 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#84)*{c#84 <- `c*`}) -- let{`c_1*` : lane_*} c_1#105*{c_1#105 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#109*{c#109 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} + -- let{`c*` : iN*} c#83*{c#83 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#110)))*{c#110 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#114)*{c#114 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#86)*{c#86 <- `c*`}) -- let{`c_1*` : lane_*} c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#112*{c#112 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} + -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#113)))*{c#113 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#117)*{c#117 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#88)*{c#88 <- `c*`}) -- let{`c_1*` : lane_*} c_1#109*{c_1#109 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#115*{c#115 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} + -- let{`c*` : iN*} c#87*{c#87 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#116)))*{c#116 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#120)*{c#120 <- `c*`}) + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) -- let{`c_1*` : lane_*} c_1#111*{c_1#111 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c#118*{c#118 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} + -- let{`c*` : iN*} c#89*{c#89 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#119)))*{c#119 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 +relation fun_ivbitmaskop_: `%%%`(shape, vec_, u32) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_0{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- let{`c_1*` : lane_*} c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- let{`c_1*` : lane_*} c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- let{`c_1*` : lane_*} c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- let{`c_1*` : lane_*} c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) @@ -9460,59 +12129,62 @@ def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#123)*{c#123 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#92)*{c#92 <- `c*`}) -- let{`c_1*` : lane_*} c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#121*{c#121 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} + -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), mk_lane__2_lane_(I32_Jnn, c#122)))*{c#122 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#126)*{c#126 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#94)*{c#94 <- `c*`}) -- let{`c_1*` : lane_*} c_1#127*{c_1#127 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#85*{c_2#85 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#124*{c#124 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} + -- let{`c*` : iN*} c#93*{c#93 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), mk_lane__2_lane_(I64_Jnn, c#125)))*{c#125 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#129)*{c#129 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#96)*{c#96 <- `c*`}) -- let{`c_1*` : lane_*} c_1#129*{c_1#129 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#87*{c_2#87 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#127*{c#127 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} + -- let{`c*` : iN*} c#95*{c#95 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), mk_lane__2_lane_(I8_Jnn, c#128)))*{c#128 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#132)*{c#132 <- `c*`}) + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#98)*{c#98 <- `c*`}) -- let{`c_1*` : lane_*} c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c#130*{c#130 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} + -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), mk_lane__2_lane_(I16_Jnn, c#131)))*{c#131 <- `c*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_ivshufflop_: `%%%%%`(shape, laneidx*, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139139*{i#139139 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#134*{c#134 <- `c*`}) + rule fun_ivshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139040*{i#139040 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#100*{c#100 <- `c*`})) -- let{`c_1*` : lane_*} c_1#133*{c_1#133 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#91*{c_2#91 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#133*{c#133 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139142).0]*{i#139142 <- `i*`} + -- let{`c*` : lane_*} c#99*{c#99 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139043).0]*{i#139043 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139146*{i#139146 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#136*{c#136 <- `c*`}) + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139047*{i#139047 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#102*{c#102 <- `c*`})) -- let{`c_1*` : lane_*} c_1#135*{c_1#135 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#93*{c_2#93 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#135*{c#135 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139149).0]*{i#139149 <- `i*`} + -- let{`c*` : lane_*} c#101*{c#101 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139050).0]*{i#139050 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139153*{i#139153 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#138*{c#138 <- `c*`}) + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139054*{i#139054 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#104*{c#104 <- `c*`})) -- let{`c_1*` : lane_*} c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#137*{c#137 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139156).0]*{i#139156 <- `i*`} + -- let{`c*` : lane_*} c#103*{c#103 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139057).0]*{i#139057 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139160*{i#139160 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#140*{c#140 <- `c*`}) + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139061*{i#139061 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#106*{c#106 <- `c*`})) -- let{`c_1*` : lane_*} c_1#139*{c_1#139 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) -- let{`c_2*` : lane_*} c_2#97*{c_2#97 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c#139*{c#139 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139163).0]*{i#139163 <- `i*`} + -- let{`c*` : lane_*} c#105*{c#105 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139064).0]*{i#139064 <- `i*`} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -9537,789 +12209,1310 @@ def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* +relation fun_vunop_: `%%%%`(shape, vunop_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_0{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_1{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_2{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_3{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_4{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_5{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_6{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_7{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_8{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_9{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_10{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_11{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vunop__case_12{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vunop__case_13{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vunop__case_14{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vunop__case_15{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vunop__case_16{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vunop__case_17{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vunop__case_18{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vunop__case_19{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vunop__case_20{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vunop__case_21{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vunop__case_22{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vunop__case_23{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vunop__case_24{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vunop__case_25{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vbinop_: `%%%%%`(shape, vbinop_, vec_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_8{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_9{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_10{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_11{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_24{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_25{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_26{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_27{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbinop__case_36{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbinop__case_37{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbinop__case_38{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbinop__case_39{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_40{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_41{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_42{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_43{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_44{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_45{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_46{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_47{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_48{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_49{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_50{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_51{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_52{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_53{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_54{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_55{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_56{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_57{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vbinop__case_58{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vbinop__case_59{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vternop_: `%%%%%%`(shape, vternop_, vec_, vec_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vternop__case_0{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vternop__case_1{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vternop__case_2{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vternop__case_3{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vternop__case_4{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vternop__case_5{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vternop__case_6{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vternop__case_7{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vrelop_: `%%%%%`(shape, vrelop_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_8{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_9{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_10{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_11{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vrelop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vrelop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vrelop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vrelop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_24{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_25{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_26{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_27{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + rule fun_vrelop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + rule fun_vrelop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* +relation fun_lcvtop__: `%%%%%`(shape, shape, vcvtop__, lane_, lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#143))?{c#143 <- `c?`}) - -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))))?{c#142 <- `c?`} + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#108))?{c#108 <- `c?`})) + -- let{`c?` : iN?} c#107?{c#107 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`}) - -- let{`c?` : iN?} c#144?{c#144 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#145))))?{c#145 <- `c?`} + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#110))?{c#110 <- `c?`})) + -- let{`c?` : iN?} c#109?{c#109 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#149))?{c#149 <- `c?`}) - -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#148))))?{c#148 <- `c?`} + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#112))?{c#112 <- `c?`})) + -- let{`c?` : iN?} c#111?{c#111 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#152))?{c#152 <- `c?`}) - -- let{`c?` : iN?} c#150?{c#150 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#151))))?{c#151 <- `c?`} + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#114))?{c#114 <- `c?`})) + -- let{`c?` : iN?} c#113?{c#113 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#155))?{c#155 <- `c?`}) - -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))))?{c#154 <- `c?`} + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#116))?{c#116 <- `c?`})) + -- let{`c?` : iN?} c#115?{c#115 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#158))?{c#158 <- `c?`}) - -- let{`c?` : iN?} c#156?{c#156 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#157))))?{c#157 <- `c?`} + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#118))?{c#118 <- `c?`})) + -- let{`c?` : iN?} c#117?{c#117 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#161))?{c#161 <- `c?`}) - -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#160))))?{c#160 <- `c?`} + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#120))?{c#120 <- `c?`})) + -- let{`c?` : iN?} c#119?{c#119 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`}) - -- let{`c?` : iN?} c#162?{c#162 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#163))))?{c#163 <- `c?`} + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#122))?{c#122 <- `c?`})) + -- let{`c?` : iN?} c#121?{c#121 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#167))?{c#167 <- `c?`}) - -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#166))))?{c#166 <- `c?`} + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#124))?{c#124 <- `c?`})) + -- let{`c?` : iN?} c#123?{c#123 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#170))?{c#170 <- `c?`}) - -- let{`c?` : iN?} c#168?{c#168 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#169))))?{c#169 <- `c?`} + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#126))?{c#126 <- `c?`})) + -- let{`c?` : iN?} c#125?{c#125 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#173))?{c#173 <- `c?`}) - -- let{`c?` : iN?} c#171?{c#171 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#172))))?{c#172 <- `c?`} + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#128))?{c#128 <- `c?`})) + -- let{`c?` : iN?} c#127?{c#127 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#176))?{c#176 <- `c?`}) - -- let{`c?` : iN?} c#174?{c#174 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#175))))?{c#175 <- `c?`} + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#130))?{c#130 <- `c?`})) + -- let{`c?` : iN?} c#129?{c#129 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#179))?{c#179 <- `c?`}) - -- let{`c?` : iN?} c#177?{c#177 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#178))))?{c#178 <- `c?`} + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#132))?{c#132 <- `c?`})) + -- let{`c?` : iN?} c#131?{c#131 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#182))?{c#182 <- `c?`}) - -- let{`c?` : iN?} c#180?{c#180 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#181))))?{c#181 <- `c?`} + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#134))?{c#134 <- `c?`})) + -- let{`c?` : iN?} c#133?{c#133 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#185))?{c#185 <- `c?`}) - -- let{`c?` : iN?} c#183?{c#183 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#184))))?{c#184 <- `c?`} + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#136))?{c#136 <- `c?`})) + -- let{`c?` : iN?} c#135?{c#135 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#188))?{c#188 <- `c?`}) - -- let{`c?` : iN?} c#186?{c#186 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#187))))?{c#187 <- `c?`} + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#138))?{c#138 <- `c?`})) + -- let{`c?` : iN?} c#137?{c#137 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#191))?{c#191 <- `c?`}) - -- let{`c?` : iN?} c#189?{c#189 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#190))))?{c#190 <- `c?`} + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#140))?{c#140 <- `c?`})) + -- let{`c?` : iN?} c#139?{c#139 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#194))?{c#194 <- `c?`}) - -- let{`c?` : iN?} c#192?{c#192 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#193))))?{c#193 <- `c?`} + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))?{c#142 <- `c?`})) + -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#197))?{c#197 <- `c?`}) - -- let{`c?` : iN?} c#195?{c#195 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#196))))?{c#196 <- `c?`} + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#144))?{c#144 <- `c?`})) + -- let{`c?` : iN?} c#143?{c#143 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#200))?{c#200 <- `c?`}) - -- let{`c?` : iN?} c#198?{c#198 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#199))))?{c#199 <- `c?`} + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`})) + -- let{`c?` : iN?} c#145?{c#145 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#203))?{c#203 <- `c?`}) - -- let{`c?` : iN?} c#201?{c#201 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#202))))?{c#202 <- `c?`} + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#148))?{c#148 <- `c?`})) + -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#206))?{c#206 <- `c?`}) - -- let{`c?` : iN?} c#204?{c#204 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#205))))?{c#205 <- `c?`} + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#150))?{c#150 <- `c?`})) + -- let{`c?` : iN?} c#149?{c#149 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#209))?{c#209 <- `c?`}) - -- let{`c?` : iN?} c#207?{c#207 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#208))))?{c#208 <- `c?`} + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#152))?{c#152 <- `c?`})) + -- let{`c?` : iN?} c#151?{c#151 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#212))?{c#212 <- `c?`}) - -- let{`c?` : iN?} c#210?{c#210 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#211))))?{c#211 <- `c?`} + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))?{c#154 <- `c?`})) + -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#215))?{c#215 <- `c?`}) - -- let{`c?` : iN?} c#213?{c#213 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#214))))?{c#214 <- `c?`} + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#156))?{c#156 <- `c?`})) + -- let{`c?` : iN?} c#155?{c#155 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#218))?{c#218 <- `c?`}) - -- let{`c?` : iN?} c#216?{c#216 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#217))))?{c#217 <- `c?`} + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#158))?{c#158 <- `c?`})) + -- let{`c?` : iN?} c#157?{c#157 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#221))?{c#221 <- `c?`}) - -- let{`c?` : iN?} c#219?{c#219 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#220))))?{c#220 <- `c?`} + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#160))?{c#160 <- `c?`})) + -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#224))?{c#224 <- `c?`}) - -- let{`c?` : iN?} c#222?{c#222 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#223))))?{c#223 <- `c?`} + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#162))?{c#162 <- `c?`})) + -- let{`c?` : iN?} c#161?{c#161 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`})) + -- let{`c?` : iN?} c#163?{c#163 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#227))?{c#227 <- `c?`}) - -- let{`c?` : iN?} c#225?{c#225 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#226))))?{c#226 <- `c?`} + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#166))?{c#166 <- `c?`})) + -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#230))?{c#230 <- `c?`}) - -- let{`c?` : iN?} c#228?{c#228 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#229))))?{c#229 <- `c?`} + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#168))?{c#168 <- `c?`})) + -- let{`c?` : iN?} c#167?{c#167 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#233))?{c#233 <- `c?`}) - -- let{`c?` : iN?} c#231?{c#231 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#232))))?{c#232 <- `c?`} + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#170))?{c#170 <- `c?`})) + -- let{`c?` : iN?} c#169?{c#169 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#236))?{c#236 <- `c?`}) - -- let{`c?` : iN?} c#234?{c#234 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#235))))?{c#235 <- `c?`} + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#172))*{c#172 <- `c*`}) + -- let{`c*` : fN*} c#171*{c#171 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#239))*{c#239 <- `c*`} - -- let{`c*` : fN*} c#237*{c#237 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#238))))*{c#238 <- `c*`} + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#174))*{c#174 <- `c*`}) + -- let{`c*` : fN*} c#173*{c#173 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#242))*{c#242 <- `c*`} - -- let{`c*` : fN*} c#240*{c#240 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#241))))*{c#241 <- `c*`} + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#176))*{c#176 <- `c*`}) + -- let{`c*` : fN*} c#175*{c#175 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#245))*{c#245 <- `c*`} - -- let{`c*` : fN*} c#243*{c#243 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#244))))*{c#244 <- `c*`} + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#178))*{c#178 <- `c*`}) + -- let{`c*` : fN*} c#177*{c#177 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#248))*{c#248 <- `c*`} - -- let{`c*` : fN*} c#246*{c#246 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#247))))*{c#247 <- `c*`} + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#180))*{c#180 <- `c*`}) + -- let{`c*` : fN*} c#179*{c#179 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#251))*{c#251 <- `c*`} - -- let{`c*` : fN*} c#249*{c#249 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#250))))*{c#250 <- `c*`} + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#182))*{c#182 <- `c*`}) + -- let{`c*` : fN*} c#181*{c#181 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#254))*{c#254 <- `c*`} - -- let{`c*` : fN*} c#252*{c#252 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#253))))*{c#253 <- `c*`} + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#184))*{c#184 <- `c*`}) + -- let{`c*` : fN*} c#183*{c#183 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#257))*{c#257 <- `c*`} - -- let{`c*` : fN*} c#255*{c#255 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#256))))*{c#256 <- `c*`} + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#186))*{c#186 <- `c*`}) + -- let{`c*` : fN*} c#185*{c#185 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#260))*{c#260 <- `c*`} - -- let{`c*` : fN*} c#258*{c#258 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#259))))*{c#259 <- `c*`} + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#188))*{c#188 <- `c*`}) + -- let{`c*` : fN*} c#187*{c#187 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#263))*{c#263 <- `c*`} - -- let{`c*` : fN*} c#261*{c#261 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#262))))*{c#262 <- `c*`} + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#190))*{c#190 <- `c*`}) + -- let{`c*` : fN*} c#189*{c#189 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#266))*{c#266 <- `c*`} - -- let{`c*` : fN*} c#264*{c#264 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#265))))*{c#265 <- `c*`} + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#192))*{c#192 <- `c*`}) + -- let{`c*` : fN*} c#191*{c#191 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#269))*{c#269 <- `c*`} - -- let{`c*` : fN*} c#267*{c#267 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#268))))*{c#268 <- `c*`} + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#194))*{c#194 <- `c*`}) + -- let{`c*` : fN*} c#193*{c#193 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#272))*{c#272 <- `c*`} - -- let{`c*` : fN*} c#270*{c#270 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#271))))*{c#271 <- `c*`} + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#196))*{c#196 <- `c*`}) + -- let{`c*` : fN*} c#195*{c#195 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#275))*{c#275 <- `c*`} - -- let{`c*` : fN*} c#273*{c#273 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#274))))*{c#274 <- `c*`} + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#198))*{c#198 <- `c*`}) + -- let{`c*` : fN*} c#197*{c#197 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#278))*{c#278 <- `c*`} - -- let{`c*` : fN*} c#276*{c#276 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#277))))*{c#277 <- `c*`} + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#200))*{c#200 <- `c*`}) + -- let{`c*` : fN*} c#199*{c#199 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#281))*{c#281 <- `c*`} - -- let{`c*` : fN*} c#279*{c#279 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#280))))*{c#280 <- `c*`} + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#202))*{c#202 <- `c*`}) + -- let{`c*` : fN*} c#201*{c#201 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#284))*{c#284 <- `c*`} - -- let{`c*` : fN*} c#282*{c#282 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#283))))*{c#283 <- `c*`} + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*, var_0 : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = var_0) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} + -- fun_lcvtop__: `%%%%%`(shape_1, shape_2, vcvtop__, lane_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ +relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v - -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) + rule fun_vcvtop___case_0{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M_0)), vcvtop, v_1, v) + -- if ((var_0 = ?()) /\ (var_1 = ?())) -- let{`c_1*` : lane_*} c_1#141*{c_1#141 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c#285*{c#285 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142)*{c_1#142 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#286*{c#286 <- `c*#30`})*{`c*#30` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#203*{c#203 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if (M = M_0) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142, var_2))*{var_2 <- `var_2*`, c_1#142 <- `c_1*`} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) + rule fun_vcvtop___case_1{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half, `var_1*` : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(half)) -- let{`c_1*` : lane_*} c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c#287*{c#287 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#288*{c#288 <- `c*#32`})*{`c*#32` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#205*{c#205 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144, var_1))*{var_1 <- `var_1*`, c_1#144 <- `c_1*`} + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(ZERO_zero)) -- let{`c_1*` : lane_*} c_1#145*{c_1#145 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c#289*{c#289 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#290*{c#290 <- `c*#34`})*{`c*#34` <- `c**`}) - -- wf_uN: `%%`(128, v) + -- let{`c**` : lane_**} c#207*{c#207 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [$zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}) -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146, var_1))*{var_1 <- `var_1*`, c_1#146 <- `c_1*`} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ +relation fun_vshiftop_: `%%%%%`(ishape, vshiftop_, vec_, u32, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_0{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_1{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_2{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_3{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_4{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_5{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_6{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vshiftop__case_7{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 +relation fun_vbitmaskop_: `%%%`(ishape, vec_, u32) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + rule fun_vbitmaskop__case_0{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + rule fun_vbitmaskop__case_1{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + rule fun_vbitmaskop__case_2{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{M : nat, v : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + rule fun_vbitmaskop__case_3{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vswizzlop_: `%%%%%`(bshape, vswizzlop_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vswizzlop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vswizzlop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vshufflop_: `%%%%%`(bshape, laneidx*, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139845*{i#139845 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139530*{i#139530 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vnarrowop__: `%%%%%%`(shape, shape, sx, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#147*{c_1#147 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#99*{c_2#99 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#1*{c'_1#1 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#148)))*{c_1#148 <- `c_1*`} @@ -10329,8 +13522,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#3)))*{c'_1#3 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#3)))*{c'_2#3 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#149*{c_1#149 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#101*{c_2#101 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#4*{c'_1#4 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#150)))*{c_1#150 <- `c_1*`} @@ -10340,8 +13535,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#6)))*{c'_1#6 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#6)))*{c'_2#6 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#151*{c_1#151 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#103*{c_2#103 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#7*{c'_1#7 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#152)))*{c_1#152 <- `c_1*`} @@ -10351,8 +13548,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#9)))*{c'_1#9 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#9)))*{c'_2#9 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#153*{c_1#153 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#105*{c_2#105 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#10*{c'_1#10 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#154)))*{c_1#154 <- `c_1*`} @@ -10362,8 +13561,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#12)))*{c'_1#12 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#12)))*{c'_2#12 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#155*{c_1#155 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#13*{c'_1#13 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#156)))*{c_1#156 <- `c_1*`} @@ -10373,8 +13574,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#15)))*{c'_1#15 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#15)))*{c'_2#15 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#157*{c_1#157 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#109*{c_2#109 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#16*{c'_1#16 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#158)))*{c_1#158 <- `c_1*`} @@ -10384,8 +13587,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#18)))*{c'_1#18 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#18)))*{c'_2#18 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#159*{c_1#159 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#111*{c_2#111 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#19*{c'_1#19 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#160)))*{c_1#160 <- `c_1*`} @@ -10395,8 +13600,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#21)))*{c'_1#21 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#21)))*{c'_2#21 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#113*{c_2#113 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#22*{c'_1#22 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#162)))*{c_1#162 <- `c_1*`} @@ -10406,8 +13613,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#24)))*{c'_1#24 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#24)))*{c'_2#24 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#163*{c_1#163 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#115*{c_2#115 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#25*{c'_1#25 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#164)))*{c_1#164 <- `c_1*`} @@ -10417,8 +13626,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#27)))*{c'_1#27 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#27)))*{c'_2#27 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#165*{c_1#165 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#117*{c_2#117 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#28*{c'_1#28 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#166)))*{c_1#166 <- `c_1*`} @@ -10428,8 +13639,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#30)))*{c'_1#30 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#30)))*{c'_2#30 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#167*{c_1#167 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#119*{c_2#119 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#31*{c'_1#31 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#168)))*{c_1#168 <- `c_1*`} @@ -10439,8 +13652,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#33)))*{c'_1#33 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#33)))*{c'_2#33 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#169*{c_1#169 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#121*{c_2#121 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#34*{c'_1#34 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#170)))*{c_1#170 <- `c_1*`} @@ -10450,8 +13665,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#36)))*{c'_1#36 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#36)))*{c'_2#36 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#171*{c_1#171 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#123*{c_2#123 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#37*{c'_1#37 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#172)))*{c_1#172 <- `c_1*`} @@ -10461,8 +13678,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#39)))*{c'_1#39 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#39)))*{c'_2#39 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#125*{c_2#125 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#40*{c'_1#40 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#174)))*{c_1#174 <- `c_1*`} @@ -10472,8 +13691,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#42)))*{c'_1#42 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#42)))*{c'_2#42 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#175*{c_1#175 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#127*{c_2#127 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#43*{c'_1#43 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#176)))*{c_1#176 <- `c_1*`} @@ -10483,8 +13704,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#45)))*{c'_1#45 <- `c'_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#45)))*{c'_2#45 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2) = v + rule fun_vnarrowop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- let{`c_1*` : lane_*} c_1#177*{c_1#177 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c_2*` : lane_*} c_2#129*{c_2#129 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) -- let{`c'_1*` : iN*} c'_1#46*{c'_1#46 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#178)))*{c_1#178 <- `c_1*`} @@ -10498,386 +13721,347 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139991*{i#139991 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139992).0*{i#139992 <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1#2)))*{j_1#2 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2#2)))*{j_2#2 <- `j_2*`} + def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139675*{i#139675 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139676).0*{i#139676 <- `i*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#293)*{c#293 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#210)*{c#210 <- `c*`}) -- let{`c_1*` : lane_*} c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#49*{c'_1#49 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`} - -- let{`c*` : iN*} c#291*{c#291 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#292)))*{c#292 <- `c*`} + -- let{`c*` : iN*} c#209*{c#209 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#296)*{c#296 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#212)*{c#212 <- `c*`}) -- let{`c_1*` : lane_*} c_1#181*{c_1#181 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#51*{c'_1#51 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- `c_1*`} - -- let{`c*` : iN*} c#294*{c#294 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#295)))*{c#295 <- `c*`} + -- let{`c*` : iN*} c#211*{c#211 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#299)*{c#299 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#214)*{c#214 <- `c*`}) -- let{`c_1*` : lane_*} c_1#183*{c_1#183 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- `c_1*`} - -- let{`c*` : iN*} c#297*{c#297 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#298)))*{c#298 <- `c*`} + -- let{`c*` : iN*} c#213*{c#213 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#302)*{c#302 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#216)*{c#216 <- `c*`}) -- let{`c_1*` : lane_*} c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#55*{c'_1#55 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`} - -- let{`c*` : iN*} c#300*{c#300 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#301)))*{c#301 <- `c*`} + -- let{`c*` : iN*} c#215*{c#215 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#305)*{c#305 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#218)*{c#218 <- `c*`}) -- let{`c_1*` : lane_*} c_1#187*{c_1#187 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#57*{c'_1#57 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- `c_1*`} - -- let{`c*` : iN*} c#303*{c#303 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#304)))*{c#304 <- `c*`} + -- let{`c*` : iN*} c#217*{c#217 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#308)*{c#308 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#220)*{c#220 <- `c*`}) -- let{`c_1*` : lane_*} c_1#189*{c_1#189 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- `c_1*`} - -- let{`c*` : iN*} c#306*{c#306 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#307)))*{c#307 <- `c*`} + -- let{`c*` : iN*} c#219*{c#219 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#311)*{c#311 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#222)*{c#222 <- `c*`}) -- let{`c_1*` : lane_*} c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#61*{c'_1#61 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`} - -- let{`c*` : iN*} c#309*{c#309 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#310)))*{c#310 <- `c*`} + -- let{`c*` : iN*} c#221*{c#221 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#314)*{c#314 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#224)*{c#224 <- `c*`}) -- let{`c_1*` : lane_*} c_1#193*{c_1#193 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#63*{c'_1#63 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- `c_1*`} - -- let{`c*` : iN*} c#312*{c#312 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#313)))*{c#313 <- `c*`} + -- let{`c*` : iN*} c#223*{c#223 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#317)*{c#317 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#226)*{c#226 <- `c*`}) -- let{`c_1*` : lane_*} c_1#195*{c_1#195 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- `c_1*`} - -- let{`c*` : iN*} c#315*{c#315 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#316)))*{c#316 <- `c*`} + -- let{`c*` : iN*} c#225*{c#225 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#320)*{c#320 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#228)*{c#228 <- `c*`}) -- let{`c_1*` : lane_*} c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#67*{c'_1#67 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`} - -- let{`c*` : iN*} c#318*{c#318 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#319)))*{c#319 <- `c*`} + -- let{`c*` : iN*} c#227*{c#227 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#323)*{c#323 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#230)*{c#230 <- `c*`}) -- let{`c_1*` : lane_*} c_1#199*{c_1#199 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#69*{c'_1#69 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- `c_1*`} - -- let{`c*` : iN*} c#321*{c#321 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#322)))*{c#322 <- `c*`} + -- let{`c*` : iN*} c#229*{c#229 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#326)*{c#326 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#232)*{c#232 <- `c*`}) -- let{`c_1*` : lane_*} c_1#201*{c_1#201 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- `c_1*`} - -- let{`c*` : iN*} c#324*{c#324 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#325)))*{c#325 <- `c*`} + -- let{`c*` : iN*} c#231*{c#231 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#329)*{c#329 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#234)*{c#234 <- `c*`}) -- let{`c_1*` : lane_*} c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#73*{c'_1#73 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`} - -- let{`c*` : iN*} c#327*{c#327 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#328)))*{c#328 <- `c*`} + -- let{`c*` : iN*} c#233*{c#233 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#332)*{c#332 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#236)*{c#236 <- `c*`}) -- let{`c_1*` : lane_*} c_1#205*{c_1#205 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#75*{c'_1#75 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- `c_1*`} - -- let{`c*` : iN*} c#330*{c#330 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#331)))*{c#331 <- `c*`} + -- let{`c*` : iN*} c#235*{c#235 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#335)*{c#335 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#238)*{c#238 <- `c*`}) -- let{`c_1*` : lane_*} c_1#207*{c_1#207 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- `c_1*`} - -- let{`c*` : iN*} c#333*{c#333 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#334)))*{c#334 <- `c*`} + -- let{`c*` : iN*} c#237*{c#237 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#338)*{c#338 <- `c*`}) + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#240)*{c#240 <- `c*`}) -- let{`c_1*` : lane_*} c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) -- let{`c'_1*` : iN*} c'_1#79*{c'_1#79 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`} - -- let{`c*` : iN*} c#336*{c#336 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#337)))*{c#337 <- `c*`} + -- let{`c*` : iN*} c#239*{c#239 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ +relation fun_vextunop__: `%%%%%`(ishape, ishape, vextunop__, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextunop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#1*{i_1#1 <- `i_1*`}, i_2#1*{i_2#1 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#4))*{j_1#4 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#4))*{j_2#4 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#3*{i_1#3 <- `i_1*`}, i_2#3*{i_2#3 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1#5 j_2#5]*{j_1#5 <- `j_1*`, j_2#5 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1#6))*{j_1#6 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2#6))*{j_2#6 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#341)*{c#341 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#242)*{c#242 <- `c*`}) -- let{`c_1*` : lane_*} c_1#211*{c_1#211 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#81*{c'_1#81 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#49*{c'_2#49 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`} - -- let{`c*` : iN*} c#339*{c#339 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#340)))*{c#340 <- `c*`} + -- let{`c*` : iN*} c#241*{c#241 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#344)*{c#344 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#244)*{c#244 <- `c*`}) -- let{`c_1*` : lane_*} c_1#213*{c_1#213 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#133*{c_2#133 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#51*{c'_2#51 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- `c_2*`} - -- let{`c*` : iN*} c#342*{c#342 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#343)))*{c#343 <- `c*`} + -- let{`c*` : iN*} c#243*{c#243 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#347)*{c#347 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#246)*{c#246 <- `c*`}) -- let{`c_1*` : lane_*} c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#135*{c_2#135 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#85*{c'_1#85 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- `c_2*`} - -- let{`c*` : iN*} c#345*{c#345 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#346)))*{c#346 <- `c*`} + -- let{`c*` : iN*} c#245*{c#245 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#350)*{c#350 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#248)*{c#248 <- `c*`}) -- let{`c_1*` : lane_*} c_1#217*{c_1#217 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#87*{c'_1#87 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#55*{c'_2#55 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`} - -- let{`c*` : iN*} c#348*{c#348 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#349)))*{c#349 <- `c*`} + -- let{`c*` : iN*} c#247*{c#247 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#353)*{c#353 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#250)*{c#250 <- `c*`}) -- let{`c_1*` : lane_*} c_1#219*{c_1#219 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#139*{c_2#139 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#57*{c'_2#57 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- `c_2*`} - -- let{`c*` : iN*} c#351*{c#351 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#352)))*{c#352 <- `c*`} + -- let{`c*` : iN*} c#249*{c#249 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#356)*{c#356 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#252)*{c#252 <- `c*`}) -- let{`c_1*` : lane_*} c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#141*{c_2#141 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#91*{c'_1#91 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- `c_2*`} - -- let{`c*` : iN*} c#354*{c#354 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#355)))*{c#355 <- `c*`} + -- let{`c*` : iN*} c#251*{c#251 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#359)*{c#359 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#254)*{c#254 <- `c*`}) -- let{`c_1*` : lane_*} c_1#223*{c_1#223 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#93*{c'_1#93 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#61*{c'_2#61 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`} - -- let{`c*` : iN*} c#357*{c#357 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#358)))*{c#358 <- `c*`} + -- let{`c*` : iN*} c#253*{c#253 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#362)*{c#362 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#256)*{c#256 <- `c*`}) -- let{`c_1*` : lane_*} c_1#225*{c_1#225 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#145*{c_2#145 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#63*{c'_2#63 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- `c_2*`} - -- let{`c*` : iN*} c#360*{c#360 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#361)))*{c#361 <- `c*`} + -- let{`c*` : iN*} c#255*{c#255 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#365)*{c#365 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#258)*{c#258 <- `c*`}) -- let{`c_1*` : lane_*} c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#147*{c_2#147 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#97*{c'_1#97 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- `c_2*`} - -- let{`c*` : iN*} c#363*{c#363 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#364)))*{c#364 <- `c*`} + -- let{`c*` : iN*} c#257*{c#257 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#368)*{c#368 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#260)*{c#260 <- `c*`}) -- let{`c_1*` : lane_*} c_1#229*{c_1#229 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#99*{c'_1#99 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#67*{c'_2#67 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`} - -- let{`c*` : iN*} c#366*{c#366 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#367)))*{c#367 <- `c*`} + -- let{`c*` : iN*} c#259*{c#259 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#371)*{c#371 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#262)*{c#262 <- `c*`}) -- let{`c_1*` : lane_*} c_1#231*{c_1#231 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#151*{c_2#151 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#69*{c'_2#69 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- `c_2*`} - -- let{`c*` : iN*} c#369*{c#369 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#370)))*{c#370 <- `c*`} + -- let{`c*` : iN*} c#261*{c#261 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#374)*{c#374 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#264)*{c#264 <- `c*`}) -- let{`c_1*` : lane_*} c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#153*{c_2#153 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#103*{c'_1#103 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- `c_2*`} - -- let{`c*` : iN*} c#372*{c#372 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#373)))*{c#373 <- `c*`} + -- let{`c*` : iN*} c#263*{c#263 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#377)*{c#377 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#266)*{c#266 <- `c*`}) -- let{`c_1*` : lane_*} c_1#235*{c_1#235 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#105*{c'_1#105 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#73*{c'_2#73 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`} - -- let{`c*` : iN*} c#375*{c#375 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#376)))*{c#376 <- `c*`} + -- let{`c*` : iN*} c#265*{c#265 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#380)*{c#380 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#268)*{c#268 <- `c*`}) -- let{`c_1*` : lane_*} c_1#237*{c_1#237 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#157*{c_2#157 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#75*{c'_2#75 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- `c_2*`} - -- let{`c*` : iN*} c#378*{c#378 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#379)))*{c#379 <- `c*`} + -- let{`c*` : iN*} c#267*{c#267 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#383)*{c#383 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#270)*{c#270 <- `c*`}) -- let{`c_1*` : lane_*} c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#159*{c_2#159 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#109*{c'_1#109 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- `c_2*`} - -- let{`c*` : iN*} c#381*{c#381 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#382)))*{c#382 <- `c*`} + -- let{`c*` : iN*} c#269*{c#269 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#386)*{c#386 <- `c*`}) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#272)*{c#272 <- `c*`}) -- let{`c_1*` : lane_*} c_1#241*{c_1#241 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c_2*` : lane_*} c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] -- let{`c'_1*` : iN*} c'_1#111*{c'_1#111 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- `c_1*`} -- let{`c'_2*` : iN*} c'_2#79*{c'_2#79 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`} - -- let{`c*` : iN*} c#384*{c#384 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#385)))*{c#385 <- `c*`} + -- let{`c*` : iN*} c#271*{c#271 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -10886,306 +14070,305 @@ def $ivmul_(N : N, iN*, iN*) : iN* def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1#5*{i_1#5 <- `i_1*`}, i_2#5*{i_2#5 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vextbinop__: `%%%%%%`(ishape, ishape, vextbinop__, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) + rule fun_vextbinop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_16{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_17{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_18{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_19{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_20{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_21{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_22{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_23{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_24{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_25{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_26{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_27{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_28{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_29{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_30{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_31{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_32{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_33{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_34{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_35{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_36{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_37{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_38{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_39{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_40{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_41{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_42{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_43{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_44{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_45{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_46{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + rule fun_vextbinop___case_47{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_0{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11193,14 +14376,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_1{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11208,14 +14397,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_2{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11223,14 +14418,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_3{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11238,14 +14439,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_4{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11253,14 +14460,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_5{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11268,14 +14481,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_6{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11283,14 +14502,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_7{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11298,14 +14523,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_8{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11313,14 +14544,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_9{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11328,14 +14565,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_10{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11343,14 +14586,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_11{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11358,14 +14607,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_12{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11373,14 +14628,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_13{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11388,14 +14649,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_14{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11403,14 +14670,20 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_15{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) @@ -11418,6 +14691,11 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11816,13 +15094,21 @@ def $packfield_(storagetype : storagetype, val : val) : fieldval? def $packfield_{val : val}(I32_storagetype, val) = ?($fieldval_val(val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11967,76 +15253,119 @@ def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? def $unpackfield_{numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{sx : sx, i : uN}(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.1-190.86 -def $tagsxa(externaddr*) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:196.1-196.23 - def $tagsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:197.1-197.42 - def $tagsxa{a : nat, `xa*` : externaddr*}([TAG_externaddr(a)] ++ xa#1*{xa#1 <- `xa*`}) = [a] ++ $tagsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:198.1-198.57 - def $tagsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa#2*{xa#2 <- `xa*`}) = $tagsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 +relation fun_tagsxa: `%%`(externaddr*, tagaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([TAG_externaddr(a)] ++ xa#1*{xa#1 <- `xa*`}, [a] ++ var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([externaddr] ++ xa#2*{xa#2 <- `xa*`}, var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.1-191.89 -def $globalsxa(externaddr*) : globaladdr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:200.1-200.26 - def $globalsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:201.1-201.51 - def $globalsxa{a : nat, `xa*` : externaddr*}([GLOBAL_externaddr(a)] ++ xa#3*{xa#3 <- `xa*`}) = [a] ++ $globalsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:202.1-202.63 - def $globalsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa#4*{xa#4 <- `xa*`}) = $globalsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 +relation fun_globalsxa: `%%`(externaddr*, globaladdr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([GLOBAL_externaddr(a)] ++ xa#3*{xa#3 <- `xa*`}, [a] ++ var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([externaddr] ++ xa#4*{xa#4 <- `xa*`}, var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.1-192.86 -def $memsxa(externaddr*) : memaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:204.1-204.23 - def $memsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:205.1-205.42 - def $memsxa{a : nat, `xa*` : externaddr*}([MEM_externaddr(a)] ++ xa#5*{xa#5 <- `xa*`}) = [a] ++ $memsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:206.1-206.57 - def $memsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa#6*{xa#6 <- `xa*`}) = $memsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 +relation fun_memsxa: `%%`(externaddr*, memaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([MEM_externaddr(a)] ++ xa#5*{xa#5 <- `xa*`}, [a] ++ var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([externaddr] ++ xa#6*{xa#6 <- `xa*`}, var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.1-193.88 -def $tablesxa(externaddr*) : tableaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:208.1-208.25 - def $tablesxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:209.1-209.48 - def $tablesxa{a : nat, `xa*` : externaddr*}([TABLE_externaddr(a)] ++ xa#7*{xa#7 <- `xa*`}) = [a] ++ $tablesxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:210.1-210.61 - def $tablesxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa#8*{xa#8 <- `xa*`}) = $tablesxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 +relation fun_tablesxa: `%%`(externaddr*, tableaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([TABLE_externaddr(a)] ++ xa#7*{xa#7 <- `xa*`}, [a] ++ var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([externaddr] ++ xa#8*{xa#8 <- `xa*`}, var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.1-194.87 -def $funcsxa(externaddr*) : funcaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:212.1-212.24 - def $funcsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:213.1-213.45 - def $funcsxa{a : nat, `xa*` : externaddr*}([FUNC_externaddr(a)] ++ xa#9*{xa#9 <- `xa*`}) = [a] ++ $funcsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:214.1-214.59 - def $funcsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa#10*{xa#10 <- `xa*`}) = $funcsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 +relation fun_funcsxa: `%%`(externaddr*, funcaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([FUNC_externaddr(a)] ++ xa#9*{xa#9 <- `xa*`}, [a] ++ var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([externaddr] ++ xa#10*{xa#10 <- `xa*`}, var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -12044,11 +15373,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -12059,61 +15406,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -12124,153 +15579,420 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func(state : state, funcidx : funcidx) : funcinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b#1*{b#1 <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b#2*{b#2 <- `b*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r#1*{r#1 <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r#2*{r#2 <- `r*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#3*{b#3 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b#4*{b#4 <- `b*`}], $fof(z))) + def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#2*{b#2 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_structinst{z : state, `si*` : structinst*}(z, si#1*{si#1 <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si#2*{si#2 <- `si*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai#1*{ai#1 <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai#2*{ai#2 <- `ai*`}], $fof(z))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $add_exninst{z : state, `exn*` : exninst*}(z, exn#1*{exn#1 <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn#2*{exn#2 <- `exn*`}], $fof(z))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}(tableinst, n, r) = ?(tableinst') + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%`(tableinst, n, r) -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(meminst : meminst, nat : nat) : meminst? +relation fun_growtable: `%%%%`(tableinst, nat, ref, tableinst?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growtable_case_1{x0 : tableinst, x1 : nat, x2 : ref}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_growtable_before_fun_growtable_case_1: `%%%`(x0, x1, x2) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst, var_0 : tableinst?}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !(var_0)) + -- wf_tableinst: `%`(ret_val) + -- fun_growtable: `%%%%`(tableinst, nat, ref, var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#7*{b#7 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%`(meminst, n) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#9*{b#9 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_growmem: `%%%`(meminst, nat, meminst?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_1{x0 : meminst, x1 : nat}: + `%%%`(x0, x1, ?()) + -- ~ fun_growmem_before_fun_growmem_case_1: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst, var_0 : meminst?}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !(var_0)) + -- wf_meminst: `%`(ret_val) + -- fun_growmem: `%%%`(meminst, nat, var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -12310,7 +16032,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) @@ -12319,7 +16040,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) @@ -12328,7 +16048,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) @@ -12337,7 +16056,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) @@ -12432,7 +16150,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 rule tag{s : store, a : addr, taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) @@ -12440,7 +16157,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 rule global{s : store, a : addr, globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) @@ -12448,7 +16164,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 rule mem{s : store, a : addr, meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) @@ -12456,7 +16171,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 rule table{s : store, a : addr, tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) @@ -12464,7 +16178,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, funcinst : funcinst}: `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) @@ -12482,29 +16195,94 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) } ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype +relation fun_inst_valtype: `%%%`(moduleinst, valtype, valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_valtype_case_0{moduleinst : moduleinst, t : valtype, var_0 : valtype}: + `%%%`(moduleinst, t, var_0) + -- fun_subst_all_valtype: `%%%`(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_inst_valtype: `%%%`(moduleinst, valtype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_reftype: `%%%`(moduleinst, reftype, reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_reftype_case_0{moduleinst : moduleinst, rt : reftype, var_0 : reftype}: + `%%%`(moduleinst, rt, var_0) + -- fun_subst_all_reftype: `%%%`(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype, var_0 : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_reftype: `%`(ret_val) + -- fun_inst_reftype: `%%%`(moduleinst, reftype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_globaltype: `%%%`(moduleinst, globaltype, globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_globaltype_case_0{moduleinst : moduleinst, gt : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, gt, var_0) + -- fun_subst_all_globaltype: `%%%`(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}) + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_globaltype: `%`(ret_val) + -- fun_inst_globaltype: `%%%`(moduleinst, globaltype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype +relation fun_inst_memtype: `%%%`(moduleinst, memtype, memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- moduleinst.TYPES_moduleinst}) + rule fun_inst_memtype_case_0{moduleinst : moduleinst, mt : memtype, var_0 : memtype}: + `%%%`(moduleinst, mt, var_0) + -- fun_subst_all_memtype: `%%%`(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- moduleinst.TYPES_moduleinst}) + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype, var_0 : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_memtype: `%`(ret_val) + -- fun_inst_memtype: `%%%`(moduleinst, memtype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype +relation fun_inst_tabletype: `%%%`(moduleinst, tabletype, tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}) + rule fun_inst_tabletype_case_0{moduleinst : moduleinst, tt : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tt, var_0) + -- fun_subst_all_tabletype: `%%%`(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- moduleinst.TYPES_moduleinst}) + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_tabletype: `%`(ret_val) + -- fun_inst_tabletype: `%%%`(moduleinst, tabletype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) @@ -12540,7 +16318,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12550,7 +16327,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_2)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) @@ -12560,7 +16336,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12569,7 +16344,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) @@ -12585,6 +16359,7 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) -- if ($proj_uN_0(l).0 = 0) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: @@ -12602,7 +16377,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-true`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12611,7 +16385,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-false`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12620,7 +16393,6 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `br_table-lt`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])) @@ -12628,7 +16400,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) @@ -12686,11 +16457,13 @@ relation Step_pure: `%~>%`(instr*, instr*) rule `frame-vals`{n : n, f : frame, `val*` : val*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})], $instr_val(val)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: @@ -12745,7 +16518,6 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.i31`{i : num_}: `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`REF.I31`_instr) -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) @@ -12863,46 +16635,52 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: + rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (|$unop_(nt, unop, c_1)| > 0) - -- if (c <- $unop_(nt, unop, c_1)) + -- if (c <- var_0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: + rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) - -- if ($unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: + rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- if (c <- var_0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: + rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) - -- if ($binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12910,35 +16688,38 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: + rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (|$cvtop__(nt_1, nt_2, cvtop, c_1)| > 0) - -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- if (c <- var_0) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: + rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12946,8 +16727,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -12956,8 +16737,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12967,132 +16748,152 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: + rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $vunop_(sh, vunop, c_1)) + -- if (c <- var_0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: + rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) - -- if ($vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: + rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- if (c <- var_0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: + rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: + rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vternop_(sh, vternop, c_1, c_2, c_3)| > 0) - -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- if (c <- var_0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: + rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, var_0 : nat}: `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) - -- if ($proj_num__0(c) =/= ?()) - -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`})) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- fun_prod: `%%`($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: + rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vrelop_: `%%%%%`(sh, vrelop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: + rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshiftop_: `%%%%%`(sh, vshiftop, c_1, !($proj_num__0(i)), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: + rule vbitmask{c_1 : vec_, sh : ishape, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) - -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- if (!($proj_num__0(c)) = var_0) + -- wf_uN: `%%`(32, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- fun_vbitmaskop_: `%%%`(sh, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: + rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vswizzlop_: `%%%%%`(sh, swizzlop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: + rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshufflop_: `%%%%%`(sh, i*{i <- `i*`}, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -13101,8 +16902,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)|) -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) @@ -13112,10 +16913,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) - -- if ($proj_num__0(c_2) =/= ?()) - -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)|) -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) @@ -13125,6 +16925,9 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -13132,76 +16935,102 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape(Lnn, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: + rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextunop__: `%%%%%`(sh_1, sh_2, vextunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: + rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextbinop__: `%%%%%%`(sh_1, sh_2, vextbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: + rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VEXTTERNOP_instr(sh_2, sh_1, vextternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextternop__: `%%%%%%%`(sh_1, sh_2, vextternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: + rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vnarrowop__: `%%%%%%`($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: + rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vcvtop__: `%%%%%`(sh_1, sh_2, vcvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -def $blocktype_(state : state, blocktype : blocktype) : instrtype +relation fun_blocktype_: `%%%`(state, blocktype, instrtype) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule fun_blocktype__case_0{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%`(z, _IDX_blocktype(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#2*{t_1#2 <- `t_1*`}), `%`_resulttype(t_2#2*{t_2#2 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), [], `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + rule fun_blocktype__case_1{z : state, `t?` : valtype?}: + `%%%`(z, _RESULT_blocktype(t#1?{t#1 <- `t?`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t#1?{t#1 <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t#2?{t#2 <- `t?`})))) + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype, var_0 : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_instrtype: `%`(ret_val) + -- fun_blocktype_: `%%%`(state, blocktype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: + rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: + rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_throw_ref-handler-next`: `%`(config) @@ -13221,11 +17050,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13233,11 +17061,10 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -13246,8 +17073,8 @@ relation `Step_read_before_table.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13256,9 +17083,9 @@ relation `Step_read_before_table.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13274,9 +17101,9 @@ relation `Step_read_before_table.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13286,8 +17113,6 @@ relation `Step_read_before_table.copy-gt`: `%`(config) rule `table.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) @@ -13309,9 +17134,9 @@ relation `Step_read_before_table.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13320,9 +17145,9 @@ relation `Step_read_before_table.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13331,8 +17156,8 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13341,9 +17166,9 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13359,9 +17184,9 @@ relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13370,37 +17195,57 @@ relation `Step_read_before_memory.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.test-false`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: + rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: + rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-zero`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_array.fill-zero`: `%`(config) +relation `Step_read_before_array.fill-succ`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13409,18 +17254,16 @@ relation `Step_read_before_array.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13436,18 +17279,16 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13458,9 +17299,6 @@ relation `Step_read_before_array.copy-gt`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -13485,18 +17323,16 @@ relation `Step_read_before_array.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13505,17 +17341,41 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13525,9 +17385,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13535,9 +17394,8 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -13554,9 +17412,8 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13564,36 +17421,47 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: + rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: + rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*, var_0 : instrtype}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: + rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: @@ -13602,10 +17470,12 @@ relation Step_read: `%~>%`(config, instr*) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: + rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast_fail-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: @@ -13617,9 +17487,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) @@ -13633,24 +17502,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) - -- if (a < |$funcinst(z)|) -- if ($funcinst(z)[a] = fi) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) @@ -13676,12 +17546,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) - -- if (a < |$funcinst(z)|) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-null`{z : state}: @@ -13721,22 +17594,20 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- if (a < |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -13762,18 +17633,24 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: + rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13781,13 +17658,14 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) @@ -13795,7 +17673,7 @@ relation Step_read: `%~>%`(config, instr*) rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [$instr_ref($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) - -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13803,6 +17681,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -13810,15 +17689,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13826,7 +17704,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) @@ -13839,9 +17716,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -13855,8 +17732,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) @@ -13872,8 +17747,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) @@ -13888,17 +17761,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) @@ -13906,11 +17777,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) @@ -13922,86 +17791,94 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) @@ -14010,37 +17887,42 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) @@ -14051,6 +17933,7 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -14058,15 +17941,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -14074,7 +17956,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) @@ -14087,17 +17968,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) @@ -14105,8 +17984,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) @@ -14123,8 +18000,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) @@ -14141,17 +18016,15 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -14159,9 +18032,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) @@ -14182,16 +18052,17 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.func`{z : state, x : idx}: `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: + rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.test-false`{s : store, f : frame, ref : ref, rt : reftype}: @@ -14201,10 +18072,12 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.cast-fail`{s : store, f : frame, ref : ref, rt : reftype}: @@ -14217,10 +18090,10 @@ relation Step_read: `%~>%`(config, instr*) rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`val*`| = |`zt*`|) - -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- `zt*`} -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14234,11 +18107,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) - -- if ($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) - -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) - -- if (a < |$structinst(z)|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14246,9 +18117,10 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14256,27 +18128,27 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), $instr_ref(ref)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- if (n = |`ref*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(i) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14284,15 +18156,18 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- (if ($cunpack(zt) =/= ?()))^n{} -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zsize(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (n = |`c*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -14303,20 +18178,17 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) - -- if ($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if (a < |$arrayinst(z)|) - -- if ($proj_num__0(i) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14329,7 +18201,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-array`{z : state, a : addr}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) - -- if (a < |$arrayinst(z)|) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) @@ -14342,28 +18213,22 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (n =/= 0) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14387,45 +18252,31 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (n =/= 0) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14443,11 +18294,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_array.copy-gt`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) @@ -14471,43 +18319,33 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ($proj_num__0(j) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_ref(ref) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14526,9 +18364,8 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -14536,9 +18373,8 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14553,14 +18389,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- if ($cunpack(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- ~ `Step_read_before_array.init_data-num`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) @@ -14630,15 +18466,17 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if (a = |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (n = |`val*`|) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule `local.set`{z : state, val : val, x : idx}: @@ -14655,32 +18493,35 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 - rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_0 : tableinst?}: `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) - -- if (ti = !($growtable($table(z, x), n, ref))) + -- if (ti = !(var_0)) + -- wf_tableinst: `%`(!(var_0)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:352.1-353.87 - rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:413.1-414.51 rule `elem.drop`{z : state, x : idx}: @@ -14691,86 +18532,87 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(c) =/= ?()) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c)))) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) - -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)|) -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 - rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_0 : meminst?}: `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) - -- if (mi = !($growmem($mem(z, x), n))) + -- if (mi = !(var_0)) + -- wf_meminst: `%`(!(var_0)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- fun_growmem: `%%%`($mem(z, x), n, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:554.1-555.84 - rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:615.1-616.51 rule `data.drop`{z : state, x : idx}: @@ -14783,12 +18625,17 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- if (n = |`val*`|) + -- if (n = |`mut?*`|) + -- if (n = |`zt*`|) + -- if (n = |`val*`|) + -- if (n = |`zt*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: @@ -14799,8 +18646,6 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) - -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) @@ -14810,12 +18655,13 @@ relation Step: `%~>%`(config, config) rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: @@ -14826,17 +18672,14 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($packfield_(zt, val) =/= ?()) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) @@ -14875,220 +18718,465 @@ relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.1-7.63 -def $alloctypes(type*) : deftype* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:8.1-8.27 - def $alloctypes([]) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:9.1-13.24 - def $alloctypes{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN}(type'#1*{type'#1 <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} - -- let{`deftype'*` : deftype*} deftype'#1*{deftype'#1 <- `deftype'*`} = $alloctypes(type'#2*{type'#2 <- `type'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 +relation fun_alloctypes: `%%`(type*, deftype*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- let{`deftype'*` : deftype*} deftype'#1*{deftype'#1 <- `deftype'*`} = var_0 -- let{rectype : rectype} TYPE_type(rectype) = type - -- if (deftype#1*{deftype#1 <- `deftype*`} = $subst_all_deftypes($rolldt(x, rectype), $typeuse_deftype(deftype'#2)*{deftype'#2 <- `deftype'*`})) + -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) -- wf_uN: `%%`(32, x) + -- fun_rolldt: `%%%`(x, rectype, var_2) + -- fun_subst_all_deftypes: `%%%`(var_2, $typeuse_deftype(deftype'#2)*{deftype'#2 <- `deftype'*`}, var_1) + -- fun_alloctypes: `%%`(type'#2*{type'#2 <- `type'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) +relation fun_alloctag: `%%%`(store, tagtype, (store, tagaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) + rule fun_alloctag_case_0{s : store, tagtype : typeuse, taginst : taginst}: + `%%%`(s, tagtype, (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|)) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr), var_0 : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctag: `%%%`(store, tagtype, var_0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.1-20.102 -def $alloctags(store : store, tagtype*) : (store, tagaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:21.1-21.34 - def $alloctags{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:22.1-24.49 - def $alloctags{s : store, tagtype : typeuse, `tagtype'*` : tagtype*}(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) - -- let{ja : tagaddr, s_1 : store} (s_1, ja) = $alloctag(s, tagtype) - -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = $alloctags(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- let{ja : tagaddr, s_1 : store} (s_1, ja) = var_0 + -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = var_1 + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*), var_1 : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_alloctags: `%%%`(store, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocglobal: `%%%%`(store, globaltype, val, (store, globaladdr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) + rule fun_allocglobal_case_0{s : store, globaltype : globaltype, val : val, globalinst : globalinst}: + `%%%%`(s, globaltype, val, (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|)) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr), var_0 : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobal: `%%%%`(store, globaltype, val, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation fun_allocglobals: `%%%%`(store, globaltype*, val*, (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: + `%%%%`(s, [globaltype] ++ globaltype'#1*{globaltype'#1 <- `globaltype'*`}, [val] ++ val'#1*{val'#1 <- `val'*`}, (s_2, [ga] ++ ga'*{ga' <- `ga'*`})) + -- let{ga : globaladdr, s_1 : store} (s_1, ga) = var_0 + -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1 + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.1-31.122 -def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:32.1-32.42 - def $allocglobals{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:33.1-35.62 - def $allocglobals{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*}(s, [globaltype] ++ globaltype'#1*{globaltype'#1 <- `globaltype'*`}, [val] ++ val'#1*{val'#1 <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) - -- let{ga : globaladdr, s_1 : store} (s_1, ga) = $allocglobal(s, globaltype, val) - -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = $allocglobals(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*), var_2 : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobals: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(store : store, memtype : memtype) : (store, memaddr) +relation fun_allocmem: `%%%`(store, memtype, (store, memaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) + rule fun_allocmem_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}: + `%%%`(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`})), (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|)) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr), var_0 : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocmem: `%%%`(store, memtype, var_0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.1-42.102 -def $allocmems(store : store, memtype*) : (store, memaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:43.1-43.34 - def $allocmems{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:44.1-46.49 - def $allocmems{s : store, memtype : memtype, `memtype'*` : memtype*}(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) - -- let{ma : memaddr, s_1 : store} (s_1, ma) = $allocmem(s, memtype) - -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = $allocmems(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- let{ma : memaddr, s_1 : store} (s_1, ma) = var_0 + -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = var_1 + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*), var_1 : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocmems: `%%%`(store, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_alloctable: `%%%%`(store, tabletype, ref, (store, tableaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) + rule fun_alloctable_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}: + `%%%%`(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|)) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr), var_0 : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctable: `%%%%`(store, tabletype, ref, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation fun_alloctables: `%%%%`(store, tabletype*, ref*, (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: + `%%%%`(s, [tabletype] ++ tabletype'#1*{tabletype'#1 <- `tabletype'*`}, [ref] ++ ref'#1*{ref'#1 <- `ref'*`}, (s_2, [ta] ++ ta'*{ta' <- `ta'*`})) + -- let{ta : tableaddr, s_1 : store} (s_1, ta) = var_0 + -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1 + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.1-53.118 -def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:54.1-54.41 - def $alloctables{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:55.1-57.60 - def $alloctables{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*}(s, [tabletype] ++ tabletype'#1*{tabletype'#1 <- `tabletype'*`}, [ref] ++ ref'#1*{ref'#1 <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) - -- let{ta : tableaddr, s_1 : store} (s_1, ta) = $alloctable(s, tabletype, ref) - -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = $alloctables(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*), var_2 : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_alloctables: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) +relation fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, (store, funcaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) + rule fun_allocfunc_case_0{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}: + `%%%%%`(s, deftype, funccode, moduleinst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|)) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr), var_0 : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, var_0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.1-64.133 -def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funcaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:65.1-65.45 - def $allocfuncs{s : store}(s, [], [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:66.1-68.71 - def $allocfuncs{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*}(s, [dt] ++ dt'#3*{dt'#3 <- `dt'*`}, [funccode] ++ funccode'#1*{funccode'#1 <- `funccode'*`}, [moduleinst] ++ moduleinst'#1*{moduleinst'#1 <- `moduleinst'*`}) = (s_2, [fa] ++ fa'*{fa' <- `fa'*`}) - -- let{fa : funcaddr, s_1 : store} (s_1, fa) = $allocfunc(s, dt, funccode, moduleinst) - -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = $allocfuncs(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_0{s : store}: + `%%%%%`(s, [], [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_1{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*, var_1 : (store, funcaddr*), var_0 : (store, funcaddr)}: + `%%%%%`(s, [dt] ++ dt'#3*{dt'#3 <- `dt'*`}, [funccode] ++ funccode'#1*{funccode'#1 <- `funccode'*`}, [moduleinst] ++ moduleinst'#1*{moduleinst'#1 <- `moduleinst'*`}, (s_2, [fa] ++ fa'*{fa' <- `fa'*`})) + -- let{fa : funcaddr, s_1 : store} (s_1, fa) = var_0 + -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1 + -- fun_allocfuncs: `%%%%%`(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}, var_1) + -- fun_allocfunc: `%%%%%`(s, dt, funccode, moduleinst, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*), var_3 : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = var_3) + -- wf_store: `%`(ret_val.0) + -- fun_allocfuncs: `%%%%%`(store, var_0, var_1, var_2, var_3) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocdata: `%%%%`(store, datatype, byte*, (store, dataaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte#2*{byte#2 <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) + rule fun_allocdata_case_0{s : store, `byte*` : byte*, datainst : datainst}: + `%%%%`(s, OK_datatype, byte#2*{byte#2 <- `byte*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|)) -- if (datainst = {BYTES byte#3*{byte#3 <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte#4*{byte#4 <- `byte*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr), var_1 : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocdata: `%%%%`(store, datatype, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation fun_allocdatas: `%%%%`(store, datatype*, byte**, (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#8*{b#8 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}, (s_2, [da] ++ da'*{da' <- `da'*`})) + -- let{da : dataaddr, s_1 : store} (s_1, da) = var_0 + -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = var_1 + -- fun_allocdatas: `%%%%`(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}, var_1) + -- fun_allocdata: `%%%%`(s, ok, b#9*{b#9 <- `b*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.1-75.118 -def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 - def $allocdatas{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#10*{b#10 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b#11*{b#11 <- `b*`}) - -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = $allocdatas(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*), var_2 : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocdatas: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) +relation fun_allocelem: `%%%%`(store, elemtype, ref*, (store, elemaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref#1*{ref#1 <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) + rule fun_allocelem_case_0{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}: + `%%%%`(s, elemtype, ref#1*{ref#1 <- `ref*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|)) -- if (eleminst = {TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr), var_1 : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocelem: `%%%%`(store, elemtype, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation fun_allocelems: `%%%%`(store, elemtype*, ref**, (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: + `%%%%`(s, [rt] ++ rt'#1*{rt'#1 <- `rt'*`}, [ref#4*{ref#4 <- `ref*`}] ++ ref'#3*{ref'#3 <- `ref'*#1`}*{`ref'*#1` <- `ref'**`}, (s_2, [ea] ++ ea'*{ea' <- `ea'*`})) + -- let{ea : elemaddr, s_1 : store} (s_1, ea) = var_0 + -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1 + -- fun_allocelems: `%%%%`(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}, var_1) + -- fun_allocelem: `%%%%`(s, rt, ref#5*{ref#5 <- `ref*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.1-86.117 -def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:87.1-87.40 - def $allocelems{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:88.1-90.55 - def $allocelems{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**}(s, [rt] ++ rt'#1*{rt'#1 <- `rt'*`}, [ref#4*{ref#4 <- `ref*`}] ++ ref'#3*{ref'#3 <- `ref'*#1`}*{`ref'*#1` <- `ref'**`}) = (s_2, [ea] ++ ea'*{ea' <- `ea'*`}) - -- let{ea : elemaddr, s_1 : store} (s_1, ea) = $allocelem(s, rt, ref#5*{ref#5 <- `ref*`}) - -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = $allocelems(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*), var_2 : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocelems: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#4*{export#4 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#3*{export#3 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) +relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref**, (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#4*{global#4 <- `global*`}), `%`_list(mem#4*{mem#4 <- `mem*`}), `%`_list(table#4*{table#4 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#4*{elem#4 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#5*{export#5 <- `export*`})) = module + rule fun_allocmodule_case_0{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*, var_17 : (store, funcaddr*), `var_16*` : elemtype*, var_15 : (store, elemaddr*), var_14 : (store, dataaddr*), `var_13*` : tabletype*, var_12 : (store, tableaddr*), `var_11*` : memtype*, var_10 : (store, memaddr*), `var_9*` : globaltype*, var_8 : (store, globaladdr*), `var_7*` : tagtype*, var_6 : (store, tagaddr*), var_5 : deftype*, var_4 : funcaddr*, var_3 : tableaddr*, var_2 : memaddr*, var_1 : globaladdr*, var_0 : tagaddr*}: + `%%%%%%%`(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}, (s_7, moduleinst)) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#4*{export#4 <- `export*`})) = module -- if (tag#3*{tag#3 <- `tag*`} = TAG_tag(tagtype#78)*{tagtype#78 <- `tagtype*`}) - -- if (global#5*{global#5 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) - -- if (mem#5*{mem#5 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) - -- if (table#5*{table#5 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) + -- if (global#4*{global#4 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) + -- if (mem#4*{mem#4 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) + -- if (table#4*{table#4 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) -- if (func#4*{func#4 <- `func*`} = FUNC_func(x#2, local#2*{local#2 <- `local*#82`}, expr_F#1)*{expr_F#1 <- `expr_F*`, `local*#82` <- `local**`, x#2 <- `x*`}) -- if (data#3*{data#3 <- `data*`} = DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`}) - -- if (elem#5*{elem#5 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) - -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`}) - -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`}) - -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`}) - -- let{`ta_I*` : tableaddr*} ta_I#1*{ta_I#1 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`}) - -- let{`fa_I*` : funcaddr*} fa_I#1*{fa_I#1 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`}) - -- let{`dt*` : deftype*} dt#8*{dt#8 <- `dt*`} = $alloctypes(type#3*{type#3 <- `type*`}) + -- if (elem#4*{elem#4 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) + -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = var_0 + -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = var_1 + -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = var_2 + -- let{`ta_I*` : tableaddr*} ta_I#1*{ta_I#1 <- `ta_I*`} = var_3 + -- let{`fa_I*` : funcaddr*} fa_I#1*{fa_I#1 <- `fa_I*`} = var_4 + -- let{`dt*` : deftype*} dt#8*{dt#8 <- `dt*`} = var_5 -- let{`fa*` : nat*} fa#1*{fa#1 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#5*{func#5 <- `func*`}|){} - -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa#1*{aa#1 <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype#80, $typeuse_deftype(dt#9)*{dt#9 <- `dt*`})*{tagtype#80 <- `tagtype*`}) - -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga#1*{ga#1 <- `ga*`}) = $allocglobals(s_1, $subst_all_globaltype(globaltype#124, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`})*{globaltype#124 <- `globaltype*`}, val_G#2*{val_G#2 <- `val_G*`}) - -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma#1*{ma#1 <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype#124, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`})*{memtype#124 <- `memtype*`}) - -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta#1*{ta#1 <- `ta*`}) = $alloctables(s_3, $subst_all_tabletype(tabletype#158, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`})*{tabletype#158 <- `tabletype*`}, ref_T#2*{ref_T#2 <- `ref_T*`}) - -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = $allocdatas(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}) - -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`})*{elemtype#2 <- `elemtype*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}) - -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = $allocfuncs(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{})) - -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#6*{export#6 <- `export*`})) + -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa#1*{aa#1 <- `aa*`}) = var_6 + -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga#1*{ga#1 <- `ga*`}) = var_8 + -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma#1*{ma#1 <- `ma*`}) = var_10 + -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta#1*{ta#1 <- `ta*`}) = var_12 + -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = var_14 + -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = var_15 + -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = var_17) + -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#5*{export#5 <- `export*`})) -- if (moduleinst = {TYPES dt#15*{dt#15 <- `dt*`}, TAGS aa_I#3*{aa_I#3 <- `aa_I*`} ++ aa#3*{aa#3 <- `aa*`}, GLOBALS ga_I#3*{ga_I#3 <- `ga_I*`} ++ ga#3*{ga#3 <- `ga*`}, MEMS ma_I#3*{ma_I#3 <- `ma_I*`} ++ ma#3*{ma#3 <- `ma*`}, TABLES ta_I#3*{ta_I#3 <- `ta_I*`} ++ ta#3*{ta#3 <- `ta*`}, FUNCS fa_I#3*{fa_I#3 <- `fa_I*`} ++ fa#4*{fa#4 <- `fa*`}, DATAS da#2*{da#2 <- `da*`}, ELEMS ea#2*{ea#2 <- `ea*`}, EXPORTS xi#2*{xi#2 <- `xi*`}}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- `tagtype*`} -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- `expr_G*`, globaltype#125 <- `globaltype*`} -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- `memtype*`} @@ -15098,125 +19186,279 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- (wf_elem: `%`(ELEM_elem(elemtype#3, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)))*{elemmode#232 <- `elemmode*`, elemtype#3 <- `elemtype*`, `expr_E*#2` <- `expr_E**`} -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#4*{aa_I#4 <- `aa_I*`} ++ aa#4*{aa#4 <- `aa*`}, GLOBALS ga_I#4*{ga_I#4 <- `ga_I*`} ++ ga#4*{ga#4 <- `ga*`}, MEMS ma_I#4*{ma_I#4 <- `ma_I*`} ++ ma#4*{ma#4 <- `ma*`}, TABLES ta_I#4*{ta_I#4 <- `ta_I*`} ++ ta#4*{ta#4 <- `ta*`}, FUNCS fa_I#4*{fa_I#4 <- `fa_I*`} ++ fa#5*{fa#5 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt#16*{dt#16 <- `dt*`}, TAGS aa_I#5*{aa_I#5 <- `aa_I*`} ++ aa#5*{aa#5 <- `aa*`}, GLOBALS ga_I#5*{ga_I#5 <- `ga_I*`} ++ ga#5*{ga#5 <- `ga*`}, MEMS ma_I#5*{ma_I#5 <- `ma_I*`} ++ ma#5*{ma#5 <- `ma*`}, TABLES ta_I#5*{ta_I#5 <- `ta_I*`} ++ ta#5*{ta#5 <- `ta*`}, FUNCS fa_I#5*{fa_I#5 <- `fa_I*`} ++ fa#6*{fa#6 <- `fa*`}, DATAS da#3*{da#3 <- `da*`}, ELEMS ea#3*{ea#3 <- `ea*`}, EXPORTS xi#3*{xi#3 <- `xi*`}}) + -- fun_allocfuncs: `%%%%%`(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{}, var_17) + -- (fun_subst_all_reftype: `%%%`(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#2 <- `elemtype*`} + -- fun_allocelems: `%%%%`(s_5, var_16*{var_16 <- `var_16*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_15) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype#158, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#158 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- (fun_subst_all_memtype: `%%%`(memtype#124, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#124 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype#124, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#124 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- (fun_subst_all_tagtype: `%%%`(tagtype#80, $typeuse_deftype(dt#9)*{dt#9 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#80 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#3*{type#3 <- `type*`}, var_5) + -- fun_funcsxa: `%%`(externaddr#6*{externaddr#6 <- `externaddr*`}, var_4) + -- fun_tablesxa: `%%`(externaddr#5*{externaddr#5 <- `externaddr*`}, var_3) + -- fun_memsxa: `%%`(externaddr#4*{externaddr#4 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#3*{externaddr#3 <- `externaddr*`}, var_1) + -- fun_tagsxa: `%%`(externaddr#2*{externaddr#2 <- `externaddr*`}, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst), var_4 : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = var_4) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + -- fun_allocmodule: `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, var_4) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $rundata_(dataidx : dataidx, data : data) : instr* +relation fun_rundata_: `%%%`(dataidx, data, instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b#12^n{b#12 <- `b*`}, PASSIVE_datamode)) = [] + rule fun_rundata__case_0{x : uN, n : nat, `b*` : byte*}: + `%%%`(x, DATA_data(b#10*{b#10 <- `b*`}, PASSIVE_datamode), []) + -- if (n = |`b*`|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b#13^n{b#13 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + rule fun_rundata__case_1{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}: + `%%%`(x, DATA_data(b#11*{b#11 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)]) + -- if (n = |`b*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*, var_0 : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_rundata_: `%%%`(dataidx, data, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $runelem_(elemidx : elemidx, elem : elem) : instr* +relation fun_runelem_: `%%%`(elemidx, elem, instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#1^n{e#1 <- `e*`}, PASSIVE_elemmode)) = [] + rule fun_runelem__case_0{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#1*{e#1 <- `e*`}, PASSIVE_elemmode), []) + -- if (n = |`e*`|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e#2^n{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule fun_runelem__case_1{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#2*{e#2 <- `e*`}, DECLARE_elemmode), [`ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e#3^n{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule fun_runelem__case_2{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}: + `%%%`(x, ELEM_elem(rt, e#3*{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*, var_0 : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_runelem_: `%%%`(elemidx, elem, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.1-160.92 -def $evalexprs(state : state, expr*) : (state, ref*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:161.1-161.34 - def $evalexprs{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:162.1-165.46 - def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) - -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = $evalexprs(z', expr'#2*{expr'#2 <- `expr'*`}) - -- wf_ref: `%`(ref) + -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = var_0 -- wf_state: `%`(z') + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*), var_1 : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} + -- fun_evalexprs: `%%%`(state, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, var_1 : (state, ref**), var_0 : (state, ref*)}: + `%%%`(z, [expr#365*{expr#365 <- `expr*`}] ++ expr'#3*{expr'#3 <- `expr'*#1`}*{`expr'*#1` <- `expr'**`}, (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`})) + -- let{`ref*` : ref*, z' : state} (z', ref#6*{ref#6 <- `ref*`}) = var_0 + -- let{z'' : state, `ref'**` : ref**} (z'', ref'#6*{ref'#6 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`}) = var_1 + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 -def $evalexprss(state : state, expr**) : (state, ref**) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 - def $evalexprss{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:169.1-172.49 - def $evalexprss{z : state, `expr*` : expr*, `expr'**` : expr**}(z, [expr#365*{expr#365 <- `expr*`}] ++ expr'#3*{expr'#3 <- `expr'*#1`}*{`expr'*#1` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) - -- let{`ref*` : ref*, z' : state} (z', ref#6*{ref#6 <- `ref*`}) = $evalexprs(z, expr#366*{expr#366 <- `expr*`}) - -- let{z'' : state, `ref'**` : ref**} (z'', ref'#6*{ref'#6 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`}) = $evalexprss(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**), var_1 : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} + -- fun_evalexprss: `%%%`(state, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 -def $evalglobals(state : state, globaltype*, expr*) : (state, val*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 - def $evalglobals{z : state}(z, [], []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:176.1-181.82 - def $evalglobals{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state}(z, [gt] ++ gt'#1*{gt'#1 <- `gt'*`}, [expr] ++ expr'#5*{expr'#5 <- `expr'*`}) = (z'', [val] ++ val'*{val' <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_0{z : state}: + `%%%%`(z, [], [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state, var_1 : (state, val*), var_0 : (store, globaladdr)}: + `%%%%`(z, [gt] ++ gt'#1*{gt'#1 <- `gt'*`}, [expr] ++ expr'#5*{expr'#5 <- `expr'*`}, (z'', [val] ++ val'*{val' <- `val'*`})) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) -- let{s : store, f : frame} `%;%`_state(s, f) = z' - -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) - -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}) - -- wf_val: `%`(val) + -- let{s' : store, a : addr} (s', a) = var_0 + -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = var_1 -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- fun_evalglobals: `%%%%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, gt, val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*), var_2 : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} + -- fun_evalglobals: `%%%%`(state, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $instantiate(store : store, module : module, externaddr*) : config +relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat, var_11 : funcaddr*, var_10 : globaladdr*, var_9 : deftype*, `var_8*` : instr**, `var_7*` : instr**, var_6 : (store, moduleinst), var_5 : (state, ref**), var_4 : (state, ref*), var_3 : (state, val*), var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: + `%%%%`(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- `externaddr*`, xt_I#2 <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#7*{global#7 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#7*{table#7 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#7*{elem#7 <- `elem*`}), start#6?{start#6 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`})) = module - -- if (global#8*{global#8 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) - -- if (table#8*{table#8 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`})) = module + -- if (global#7*{global#7 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) + -- if (table#7*{table#7 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) -- if (data#7*{data#7 <- `data*`} = DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`}) - -- if (elem#8*{elem#8 <- `elem*`} = ELEM_elem(reftype#517, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#517 <- `reftype*`}) - -- if (start#7?{start#7 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) - -- if (moduleinst_0 = {TYPES $alloctypes(type#6*{type#6 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#9*{externaddr#9 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#10*{externaddr#10 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (elem#7*{elem#7 <- `elem*`} = ELEM_elem(reftype#516, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#516 <- `reftype*`}) + -- if (start#6?{start#6 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) + -- if (moduleinst_0 = {TYPES var_0, TAGS [], GLOBALS var_1, MEMS [], TABLES [], FUNCS var_2 ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = $evalglobals(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}) - -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T#3*{ref_T#3 <- `ref_T*`}) = $evalexprs(z', expr_T#4*{expr_T#4 <- `expr_T*`}) - -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E#3*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`}) = $evalexprss(z'', expr_E#4*{expr_E#4 <- `expr_E*#4`}*{`expr_E*#4` <- `expr_E**`}) + -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = var_3 + -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T#3*{ref_T#3 <- `ref_T*`}) = var_4 + -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E#3*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`}) = var_5 -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' - -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) - -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1])^(i_D#1<|data#8*{data#8 <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem#10*{elem#10 <- `elem*`}[i_E#1])^(i_E#1<|elem#9*{elem#9 <- `elem*`}|){}) + -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = var_6 + -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, var_7^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`}) + -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, var_8^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`}) -- let{`instr_S?` : instr?} instr_S#1?{instr_S#1 <- `instr_S?`} = CALL_instr(x#7)?{x#7 <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E#2*{instr_E#2 <- `instr_E*`} ++ instr_D#2*{instr_D#2 <- `instr_D*`} ++ lift(instr_S#2?{instr_S#2 <- `instr_S?`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#3*{xt_I#3 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#9*{global#9 <- `global*`}), `%`_list(mem#8*{mem#8 <- `mem*`}), `%`_list(table#9*{table#9 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#11*{elem#11 <- `elem*`}), start#8?{start#8 <- `start?`}, `%`_list(export#9*{export#9 <- `export*`}))) + -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#8*{global#8 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#10*{elem#10 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`}))) -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- `expr_G*`, globaltype#130 <- `globaltype*`} -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- `expr_T*`, tabletype#163 <- `tabletype*`} -- (wf_data: `%`(DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)))*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype#519, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#519 <- `reftype*`} + -- (wf_elem: `%`(ELEM_elem(reftype#518, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#518 <- `reftype*`} -- (wf_start: `%`(START_start(x#8)))?{x#8 <- `x?`} - -- wf_moduleinst: `%`({TYPES $alloctypes(type#8*{type#8 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#12*{externaddr#12 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#13*{externaddr#13 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES var_9, TAGS [], GLOBALS var_10, MEMS [], TABLES [], FUNCS var_11 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data#11*{data#11 <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#12*{elem#12 <- `elem*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- `x?`} + -- fun_funcsxa: `%%`(externaddr#13*{externaddr#13 <- `externaddr*`}, var_11) + -- fun_globalsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_10) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_9) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#1), elem#9*{elem#9 <- `elem*`}[i_E#1], var_8))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1], var_7))^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}, var_6) + -- fun_evalexprss: `%%%`(z'', expr_E#4*{expr_E#4 <- `expr_E*#4`}*{`expr_E*#4` <- `expr_E**`}, var_5) + -- fun_evalexprs: `%%%`(z', expr_T#4*{expr_T#4 <- `expr_T*`}, var_4) + -- fun_evalglobals: `%%%%`(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#10*{externaddr#10 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config, var_1 : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_instantiate: `%%%%`(store, module, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_invoke: `%%%%`(store, funcaddr, val*, config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_invoke_case_0{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%%`(s, funcaddr, val#1*{val#1 <- `val*`}, `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- (Val_ok: `%|-%:%`(s, val#2, t_1#5))*{t_1#5 <- `t_1*`, val#2 <- `val*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val#1*{val#1 <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val#2, t_1#7))*{t_1#7 <- `t_1*`, val#2 <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#3)*{val#3 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#8*{t_1#8 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config, var_1 : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_invoke: `%%%%`(store, funcaddr, var_0, var_1) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -15236,6 +19478,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -15276,13 +19526,30 @@ syntax I = idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.1-154.56 -def $concat_idctxt(idctxt*) : idctxt - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 - def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 - def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'#1*{I'#1 <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation fun_concat_idctxt: `%%`(idctxt*, idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_0: + `%%`([], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_1{I : idctxt, `I'*` : I*, var_0 : idctxt}: + `%%`([I] ++ I'#1*{I'#1 <- `I'*`}, I +++ var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt, var_1 : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_idctxt: `%`(ret_val) + -- fun_concat_idctxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -15303,6 +19570,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -15424,153 +19702,380 @@ relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.1-258.76 -def $typesd(decl*) : type* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:270.1-270.23 - def $typesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:271.1-271.48 - def $typesd{rectype : rectype, `decl'*` : decl*}([TYPE_decl(rectype)] ++ decl'#1*{decl'#1 <- `decl'*`}) = [TYPE_type(rectype)] ++ $typesd(decl'#2*{decl'#2 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:272.1-272.57 - def $typesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#3*{decl'#3 <- `decl'*`}) = $typesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 +relation fun_typesd: `%%`(decl*, type*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_1{rectype : rectype, `decl'*` : decl*, var_0 : type*}: + `%%`([TYPE_decl(rectype)] ++ decl'#1*{decl'#1 <- `decl'*`}, [TYPE_type(rectype)] ++ var_0) + -- fun_typesd: `%%`(decl'#2*{decl'#2 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_2{decl : decl, `decl'*` : decl*, var_0 : type*}: + `%%`([decl] ++ decl'#3*{decl'#3 <- `decl'*`}, var_0) + -- fun_typesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation fun_importsd: `%%`(decl*, import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_1{name : name, name_0 : name, externtype : externtype, `decl'*` : decl*, var_0 : import*}: + `%%`([IMPORT_decl(name, name_0, externtype)] ++ decl'#4*{decl'#4 <- `decl'*`}, [IMPORT_import(name, name_0, externtype)] ++ var_0) + -- fun_importsd: `%%`(decl'#5*{decl'#5 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_2{decl : decl, `decl'*` : decl*, var_0 : import*}: + `%%`([decl] ++ decl'#6*{decl'#6 <- `decl'*`}, var_0) + -- fun_importsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*, var_1 : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} + -- fun_importsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation fun_tagsd: `%%`(decl*, tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_1{tagtype : tagtype, `decl'*` : decl*, var_0 : tag*}: + `%%`([TAG_decl(tagtype)] ++ decl'#7*{decl'#7 <- `decl'*`}, [TAG_tag(tagtype)] ++ var_0) + -- fun_tagsd: `%%`(decl'#8*{decl'#8 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_2{decl : decl, `decl'*` : decl*, var_0 : tag*}: + `%%`([decl] ++ decl'#9*{decl'#9 <- `decl'*`}, var_0) + -- fun_tagsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*, var_1 : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tagsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation fun_globalsd: `%%`(decl*, global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_1{globaltype : globaltype, expr : expr, `decl'*` : decl*, var_0 : global*}: + `%%`([GLOBAL_decl(globaltype, expr)] ++ decl'#10*{decl'#10 <- `decl'*`}, [GLOBAL_global(globaltype, expr)] ++ var_0) + -- fun_globalsd: `%%`(decl'#11*{decl'#11 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_2{decl : decl, `decl'*` : decl*, var_0 : global*}: + `%%`([decl] ++ decl'#12*{decl'#12 <- `decl'*`}, var_0) + -- fun_globalsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*, var_1 : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation fun_memsd: `%%`(decl*, mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_1{memtype : memtype, `decl'*` : decl*, var_0 : mem*}: + `%%`([MEMORY_decl(memtype)] ++ decl'#13*{decl'#13 <- `decl'*`}, [MEMORY_mem(memtype)] ++ var_0) + -- fun_memsd: `%%`(decl'#14*{decl'#14 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_2{decl : decl, `decl'*` : decl*, var_0 : mem*}: + `%%`([decl] ++ decl'#15*{decl'#15 <- `decl'*`}, var_0) + -- fun_memsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*, var_1 : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation fun_tablesd: `%%`(decl*, table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_1{tabletype : tabletype, expr : expr, `decl'*` : decl*, var_0 : table*}: + `%%`([TABLE_decl(tabletype, expr)] ++ decl'#16*{decl'#16 <- `decl'*`}, [TABLE_table(tabletype, expr)] ++ var_0) + -- fun_tablesd: `%%`(decl'#17*{decl'#17 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_2{decl : decl, `decl'*` : decl*, var_0 : table*}: + `%%`([decl] ++ decl'#18*{decl'#18 <- `decl'*`}, var_0) + -- fun_tablesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*, var_1 : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.1-259.78 -def $importsd(decl*) : import* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:274.1-274.25 - def $importsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:275.1-275.56 - def $importsd{name : name, name_0 : name, externtype : externtype, `decl'*` : decl*}([IMPORT_decl(name, name_0, externtype)] ++ decl'#4*{decl'#4 <- `decl'*`}) = [IMPORT_import(name, name_0, externtype)] ++ $importsd(decl'#5*{decl'#5 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:276.1-276.61 - def $importsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#6*{decl'#6 <- `decl'*`}) = $importsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation fun_funcsd: `%%`(decl*, func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_1{typeidx : typeidx, `local*` : local*, expr : expr, `decl'*` : decl*, var_0 : func*}: + `%%`([FUNC_decl(typeidx, `local*`, expr)] ++ decl'#19*{decl'#19 <- `decl'*`}, [FUNC_func(typeidx, `local*`, expr)] ++ var_0) + -- fun_funcsd: `%%`(decl'#20*{decl'#20 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_2{decl : decl, `decl'*` : decl*, var_0 : func*}: + `%%`([decl] ++ decl'#21*{decl'#21 <- `decl'*`}, var_0) + -- fun_funcsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 -def $tagsd(decl*) : tag* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 - def $tagsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:279.1-279.44 - def $tagsd{tagtype : tagtype, `decl'*` : decl*}([TAG_decl(tagtype)] ++ decl'#7*{decl'#7 <- `decl'*`}) = [TAG_tag(tagtype)] ++ $tagsd(decl'#8*{decl'#8 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:280.1-280.55 - def $tagsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#9*{decl'#9 <- `decl'*`}) = $tagsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*, var_1 : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} + -- fun_funcsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 -def $globalsd(decl*) : global* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 - def $globalsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:283.1-283.56 - def $globalsd{globaltype : globaltype, expr : expr, `decl'*` : decl*}([GLOBAL_decl(globaltype, expr)] ++ decl'#10*{decl'#10 <- `decl'*`}) = [GLOBAL_global(globaltype, expr)] ++ $globalsd(decl'#11*{decl'#11 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:284.1-284.61 - def $globalsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#12*{decl'#12 <- `decl'*`}) = $globalsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation fun_datasd: `%%`(decl*, data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_1{`byte*` : byte*, datamode : datamode, `decl'*` : decl*, var_0 : data*}: + `%%`([DATA_decl(`byte*`, datamode)] ++ decl'#22*{decl'#22 <- `decl'*`}, [DATA_data(`byte*`, datamode)] ++ var_0) + -- fun_datasd: `%%`(decl'#23*{decl'#23 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_2{decl : decl, `decl'*` : decl*, var_0 : data*}: + `%%`([decl] ++ decl'#24*{decl'#24 <- `decl'*`}, var_0) + -- fun_datasd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 -def $memsd(decl*) : mem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 - def $memsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:287.1-287.44 - def $memsd{memtype : memtype, `decl'*` : decl*}([MEMORY_decl(memtype)] ++ decl'#13*{decl'#13 <- `decl'*`}) = [MEMORY_mem(memtype)] ++ $memsd(decl'#14*{decl'#14 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:288.1-288.55 - def $memsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#15*{decl'#15 <- `decl'*`}) = $memsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*, var_1 : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} + -- fun_datasd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 -def $tablesd(decl*) : table* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 - def $tablesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:291.1-291.52 - def $tablesd{tabletype : tabletype, expr : expr, `decl'*` : decl*}([TABLE_decl(tabletype, expr)] ++ decl'#16*{decl'#16 <- `decl'*`}) = [TABLE_table(tabletype, expr)] ++ $tablesd(decl'#17*{decl'#17 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:292.1-292.59 - def $tablesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#18*{decl'#18 <- `decl'*`}) = $tablesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation fun_elemsd: `%%`(decl*, elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_1{reftype : reftype, `expr*` : expr*, elemmode : elemmode, `decl'*` : decl*, var_0 : elem*}: + `%%`([ELEM_decl(reftype, `expr*`, elemmode)] ++ decl'#25*{decl'#25 <- `decl'*`}, [ELEM_elem(reftype, `expr*`, elemmode)] ++ var_0) + -- fun_elemsd: `%%`(decl'#26*{decl'#26 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_2{decl : decl, `decl'*` : decl*, var_0 : elem*}: + `%%`([decl] ++ decl'#27*{decl'#27 <- `decl'*`}, var_0) + -- fun_elemsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 -def $funcsd(decl*) : func* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 - def $funcsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:295.1-295.48 - def $funcsd{typeidx : typeidx, `local*` : local*, expr : expr, `decl'*` : decl*}([FUNC_decl(typeidx, `local*`, expr)] ++ decl'#19*{decl'#19 <- `decl'*`}) = [FUNC_func(typeidx, `local*`, expr)] ++ $funcsd(decl'#20*{decl'#20 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:296.1-296.57 - def $funcsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#21*{decl'#21 <- `decl'*`}) = $funcsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*, var_1 : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_elemsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 -def $datasd(decl*) : data* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 - def $datasd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:299.1-299.48 - def $datasd{`byte*` : byte*, datamode : datamode, `decl'*` : decl*}([DATA_decl(`byte*`, datamode)] ++ decl'#22*{decl'#22 <- `decl'*`}) = [DATA_data(`byte*`, datamode)] ++ $datasd(decl'#23*{decl'#23 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:300.1-300.57 - def $datasd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#24*{decl'#24 <- `decl'*`}) = $datasd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation fun_startsd: `%%`(decl*, start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_1{funcidx : funcidx, `decl'*` : decl*, var_0 : start*}: + `%%`([START_decl(funcidx)] ++ decl'#28*{decl'#28 <- `decl'*`}, [START_start(funcidx)] ++ var_0) + -- fun_startsd: `%%`(decl'#29*{decl'#29 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_2{decl : decl, `decl'*` : decl*, var_0 : start*}: + `%%`([decl] ++ decl'#30*{decl'#30 <- `decl'*`}, var_0) + -- fun_startsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 -def $elemsd(decl*) : elem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 - def $elemsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:303.1-303.48 - def $elemsd{reftype : reftype, `expr*` : expr*, elemmode : elemmode, `decl'*` : decl*}([ELEM_decl(reftype, `expr*`, elemmode)] ++ decl'#25*{decl'#25 <- `decl'*`}) = [ELEM_elem(reftype, `expr*`, elemmode)] ++ $elemsd(decl'#26*{decl'#26 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:304.1-304.57 - def $elemsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#27*{decl'#27 <- `decl'*`}) = $elemsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*, var_1 : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} + -- fun_startsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 -def $startsd(decl*) : start* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 - def $startsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:307.1-307.52 - def $startsd{funcidx : funcidx, `decl'*` : decl*}([START_decl(funcidx)] ++ decl'#28*{decl'#28 <- `decl'*`}) = [START_start(funcidx)] ++ $startsd(decl'#29*{decl'#29 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:308.1-308.59 - def $startsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#30*{decl'#30 <- `decl'*`}) = $startsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation fun_exportsd: `%%`(decl*, export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_1{name : name, externidx : externidx, `decl'*` : decl*, var_0 : export*}: + `%%`([EXPORT_decl(name, externidx)] ++ decl'#31*{decl'#31 <- `decl'*`}, [EXPORT_export(name, externidx)] ++ var_0) + -- fun_exportsd: `%%`(decl'#32*{decl'#32 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_2{decl : decl, `decl'*` : decl*, var_0 : export*}: + `%%`([decl] ++ decl'#33*{decl'#33 <- `decl'*`}, var_0) + -- fun_exportsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 -def $exportsd(decl*) : export* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 - def $exportsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:311.1-311.56 - def $exportsd{name : name, externidx : externidx, `decl'*` : decl*}([EXPORT_decl(name, externidx)] ++ decl'#31*{decl'#31 <- `decl'*`}) = [EXPORT_export(name, externidx)] ++ $exportsd(decl'#32*{decl'#32 <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:312.1-312.61 - def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'#33*{decl'#33 <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*, var_1 : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} + -- fun_exportsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(decl*) : bool +relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl*` : decl*}(decl#1*{decl#1 <- `decl*`}) = true - -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) + -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{name : name, name_0 : name, externtype : externtype, `decl_1*` : decl*, `decl_2*` : decl*}(decl_1#1*{decl_1#1 <- `decl_1*`} ++ [IMPORT_decl(name, name_0, externtype)] ++ decl_2#1*{decl_2#1 <- `decl_2*`}) = (((((($importsd(decl_1#7*{decl_1#7 <- `decl_1*`}) = []) /\ ($tagsd(decl_1#6*{decl_1#6 <- `decl_1*`}) = [])) /\ ($globalsd(decl_1#5*{decl_1#5 <- `decl_1*`}) = [])) /\ ($memsd(decl_1#4*{decl_1#4 <- `decl_1*`}) = [])) /\ ($tablesd(decl_1#3*{decl_1#3 <- `decl_1*`}) = [])) /\ ($funcsd(decl_1#2*{decl_1#2 <- `decl_1*`}) = [])) + rule fun_ordered_case_1{name : name, name_0 : name, externtype : externtype, `decl_1*` : decl*, `decl_2*` : decl*, var_5 : func*, var_4 : table*, var_3 : mem*, var_2 : global*, var_1 : tag*, var_0 : import*}: + `%%`(decl_1#1*{decl_1#1 <- `decl_1*`} ++ [IMPORT_decl(name, name_0, externtype)] ++ decl_2#1*{decl_2#1 <- `decl_2*`}, ((((((var_0 = []) /\ (var_1 = [])) /\ (var_2 = [])) /\ (var_3 = [])) /\ (var_4 = [])) /\ (var_5 = []))) + -- fun_funcsd: `%%`(decl_1#2*{decl_1#2 <- `decl_1*`}, var_5) + -- fun_tablesd: `%%`(decl_1#3*{decl_1#3 <- `decl_1*`}, var_4) + -- fun_memsd: `%%`(decl_1#4*{decl_1#4 <- `decl_1*`}, var_3) + -- fun_globalsd: `%%`(decl_1#5*{decl_1#5 <- `decl_1*`}, var_2) + -- fun_tagsd: `%%`(decl_1#6*{decl_1#6 <- `decl_1*`}, var_1) + -- fun_importsd: `%%`(decl_1#7*{decl_1#7 <- `decl_1*`}, var_0) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) @@ -15586,8 +20091,6 @@ relation Context_ok: `|-%:OK`(context) -- (Memtype_ok: `%|-%:OK`(C_0, mt))*{mt <- `mt*`} -- (Tabletype_ok: `%|-%:OK`(C_0, tt))*{tt <- `tt*`} -- (Deftype_ok: `%|-%:OK`(C_0, dt_F))*{dt_F <- `dt_F*`} - -- if (|`dt_F*`| = |`t_1*`|) - -- if (|`dt_F*`| = |`t_2*`|) -- (Expand: `%~~%`(dt_F, `FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} @@ -15599,10 +20102,10 @@ relation Context_ok: `|-%:OK`(context) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (n = |`dt*`|) + -- if (m = |`st*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) @@ -15655,25 +20158,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) rule _{s : store, `deftype*` : deftype*, `tagaddr*` : tagaddr*, `globaladdr*` : globaladdr*, `memaddr*` : memaddr*, `tableaddr*` : tableaddr*, `funcaddr*` : funcaddr*, `dataaddr*` : dataaddr*, `elemaddr*` : elemaddr*, `exportinst*` : exportinst*, `tagtype*` : tagtype*, `globaltype*` : globaltype*, `memtype*` : memtype*, `tabletype*` : tabletype*, `deftype_F*` : deftype*, `datatype*` : datatype*, `elemtype*` : elemtype*, `subtype*` : subtype*}: `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} - -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} - -- if (|`globaladdr*`| = |`globaltype*`|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} - -- if (|`deftype_F*`| = |`funcaddr*`|) -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} - -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} - -- if (|`tableaddr*`| = |`tabletype*`|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} - -- if (|`dataaddr*`| = |`datatype*`|) - -- (if (dataaddr < |s.DATAS_store|))*{dataaddr <- `dataaddr*`} -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} - -- if (|`elemaddr*`| = |`elemtype*`|) - -- (if (elemaddr < |s.ELEMS_store|))*{elemaddr <- `elemaddr*`} -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) - -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) @@ -15691,7 +20184,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) rule _{s : store, `val?*` : val?*, moduleinst : moduleinst, C : context, `lct*` : localtype*}: `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -15733,6 +20225,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) + -- if (n = |`t'*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: @@ -15744,6 +20237,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: @@ -15775,24 +20269,22 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:41.1-45.86 - rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`init*`| = |`t*`|) - -- if (|`init*`| = |`x_1*`|) - -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) - -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- Instrs_ok2: `%;%|-%:%`(s, !(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 rule sub{s : store, C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -15896,7 +20388,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`zt*`|) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) @@ -15918,10 +20409,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) - -- if (ta < |s.TAGS_store|) -- if ($typeuse_deftype(dt) = s.TAGS_store[ta].TYPE_taginst) -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (|`t*`| = |`val*`|) -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) @@ -15945,10 +20434,7 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) - -- if (a < |s.STRUCTS_store|) -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (i < |ft*{ft <- `ft*`}|) -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) @@ -15958,8 +20444,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) - -- if (a < |s.ARRAYS_store|) -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) @@ -15968,8 +20452,6 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule `ref.exn`{a : addr, s : store, i : nat}: `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) - -- if (i < |s.EXNS_store[a].FIELDS_exninst|) - -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) @@ -15981,42 +20463,46 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) } ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -def $NotImmutReachable(fieldval : fieldval, store : store, fieldval : fieldval) : bool +relation fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = false + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%`(fv_1, s, fv_2) -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +relation fun_NotImmutReachable: `%%%%`(fieldval, store, fieldval, bool) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = true - -- otherwise + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, false) + -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec + rule fun_NotImmutReachable_case_1{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, true) + -- ~ fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fv_1, s, fv_2) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation NotImmutReachable: `~%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{fv_1 : fieldval, s : store, fv_2 : fieldval}: + rule _{fv_1 : fieldval, s : store, fv_2 : fieldval, var_0 : bool}: `~%>>_%%`(fv_1, s, fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) + -- if var_0 -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: `|-%:OK`(s) - -- if (|`taginst*`| = |`tagtype*`|) -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} - -- if (|`globalinst*`| = |`globaltype*`|) -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} - -- if (|`meminst*`| = |`memtype*`|) -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} - -- if (|`tableinst*`| = |`tabletype*`|) -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} - -- if (|`deftype*`| = |`funcinst*`|) -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} - -- if (|`datainst*`| = |`datatype*`|) -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} - -- if (|`eleminst*`| = |`elemtype*`|) -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} @@ -16103,8 +20589,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`fv'*`|) - -- if (|`fv*`| = |`mut?*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -16116,7 +20600,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?` : mut?, zt : storagetype}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) @@ -16134,35 +20617,15 @@ relation Extend_store: `%<=%`(store, store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, s' : store}: `%<=%`(s, s') - -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} - -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} - -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} - -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} - -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} - -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} - -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} - -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} - -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} - -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} - -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} - -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} - -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} - -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} - -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} - -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} - -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} - -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} - -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} - -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -16255,7 +20718,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) @@ -16299,6 +20761,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -16324,6 +20794,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -16337,6 +20816,19 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) -- let{s_2 : store, `a'*` : addr*} (s_2, a'#1*{a'#1 <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'#2*{X'#2 <- `X'*`}, Y'#2*{Y'#2 <- `Y'*`}) } +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) +} + ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = | `%`(i : nat) @@ -16399,7 +20891,8 @@ grammar BsN(N : N) : sN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BiN(N : N) : iN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{i : sN} i:BsN(N) => `%`_iN($inv_signed_(N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:BsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BfN(N : N) : fN @@ -16449,8 +20942,9 @@ grammar Blist(syntax el, grammar BX : el) : el* ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Bname : name ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{name : name, `b*` : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name - -- if ($utf8($proj_name_0(name).0) = b*{b <- `b*`}) + prod{name : name, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name + -- if (var_0 = b*{b <- `b*`}) + -- fun_utf8: `%%`($proj_name_0(name).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Btypeidx : typeidx @@ -17937,10 +22431,11 @@ grammar Bversion : () ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bmodule : module ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**, var_0 : dataidx*} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) -- (if (n = |data*{data <- `data*`}|))?{n <- `n?`} - -- if ((n?{n <- `n?`} =/= ?()) \/ ($dataidx_funcs(func*{func <- `func*`}) = [])) + -- if ((n?{n <- `n?`} =/= ?()) \/ (var_0 = [])) -- (if (func = FUNC_func(typeidx, local*{local <- `local*`}, expr)))*{expr <- `expr*`, func <- `func*`, `local*` <- `local**`, typeidx <- `typeidx*`} + -- fun_dataidx_funcs: `%%`(func*{func <- `func*`}, var_0) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tchar : char @@ -18111,7 +22606,8 @@ grammar Tstringchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tstringelem : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tstringchar => $utf8([c]) + prod{c : char, var_0 : byte*} c:Tstringchar => var_0 + -- fun_utf8: `%%`([c], var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [`%`_byte(((16 * h_1) + h_2))] @@ -18124,8 +22620,9 @@ grammar Tstring : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tname : name ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*, `b*` : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) - -- if (b*{b <- `b*`} = $utf8(c*{c <- `c*`})) + prod{`c*` : char*, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) + -- if (b*{b <- `b*`} = var_0) + -- fun_utf8: `%%`(c*{c <- `c*`}, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tid : name @@ -18289,7 +22786,8 @@ grammar TiN(N : N) : iN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{n : n} `%`_uN(n):TuN(N) => `%`_iN(n) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{i : sN} i:TsN(N) => `%`_iN($inv_signed_(N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:TsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { @@ -18619,7 +23117,8 @@ grammar Ttypedef_(I : I) : (subtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Trectype_(I : I) : (rectype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`st*` : subtype*, `I'*` : I*} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), $concat_idctxt(I'*{I' <- `I'*`})) + prod{`st*` : subtype*, `I'*` : I*, var_0 : idctxt} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Taddrtype : addrtype @@ -18701,7 +23200,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -18772,7 +23271,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18781,7 +23280,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -19810,9 +24309,10 @@ grammar Tlocal_(I : I) : (local*, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tfunc_(I : I) : (func, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -- if (I' = I +++ I_1 +++ $concat_idctxt(I_2*{I_2 <- `I_2*`})) + prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I, var_0 : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = I +++ I_1 +++ var_0) -- Idctxt_ok: `|-%:OK`(I') + -- fun_concat_idctxt: `%%`(I_2*{I_2 <- `I_2*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdatastring : byte* @@ -19973,21 +24473,34 @@ grammar Tdecl_(I : I) : (decl, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tmodule : module ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) - -- if (I' = $concat_idctxt(I*{I <- `I*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I, var_12 : bool, var_11 : export*, var_10 : start*, var_9 : elem*, var_8 : data*, var_7 : func*, var_6 : table*, var_5 : mem*, var_4 : global*, var_3 : tag*, var_2 : import*, var_1 : type*, var_0 : idctxt} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + -- if (I' = var_0) -- Idctxt_ok: `|-%:OK`(I') - -- if (type*{type <- `type*`} = $typesd(decl*{decl <- `decl*`})) - -- if (import*{import <- `import*`} = $importsd(decl*{decl <- `decl*`})) - -- if (tag*{tag <- `tag*`} = $tagsd(decl*{decl <- `decl*`})) - -- if (global*{global <- `global*`} = $globalsd(decl*{decl <- `decl*`})) - -- if (mem*{mem <- `mem*`} = $memsd(decl*{decl <- `decl*`})) - -- if (table*{table <- `table*`} = $tablesd(decl*{decl <- `decl*`})) - -- if (func*{func <- `func*`} = $funcsd(decl*{decl <- `decl*`})) - -- if (data*{data <- `data*`} = $datasd(decl*{decl <- `decl*`})) - -- if (elem*{elem <- `elem*`} = $elemsd(decl*{decl <- `decl*`})) - -- if (lift(start?{start <- `start?`}) = $startsd(decl*{decl <- `decl*`})) - -- if (export*{export <- `export*`} = $exportsd(decl*{decl <- `decl*`})) - -- if $ordered(decl*{decl <- `decl*`}) + -- if (type*{type <- `type*`} = var_1) + -- if (import*{import <- `import*`} = var_2) + -- if (tag*{tag <- `tag*`} = var_3) + -- if (global*{global <- `global*`} = var_4) + -- if (mem*{mem <- `mem*`} = var_5) + -- if (table*{table <- `table*`} = var_6) + -- if (func*{func <- `func*`} = var_7) + -- if (data*{data <- `data*`} = var_8) + -- if (elem*{elem <- `elem*`} = var_9) + -- if (lift(start?{start <- `start?`}) = var_10) + -- if (export*{export <- `export*`} = var_11) + -- if var_12 + -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_12) + -- fun_exportsd: `%%`(decl*{decl <- `decl*`}, var_11) + -- fun_startsd: `%%`(decl*{decl <- `decl*`}, var_10) + -- fun_elemsd: `%%`(decl*{decl <- `decl*`}, var_9) + -- fun_datasd: `%%`(decl*{decl <- `decl*`}, var_8) + -- fun_funcsd: `%%`(decl*{decl <- `decl*`}, var_7) + -- fun_tablesd: `%%`(decl*{decl <- `decl*`}, var_6) + -- fun_memsd: `%%`(decl*{decl <- `decl*`}, var_5) + -- fun_globalsd: `%%`(decl*{decl <- `decl*`}, var_4) + -- fun_tagsd: `%%`(decl*{decl <- `decl*`}, var_3) + -- fun_importsd: `%%`(decl*{decl <- `decl*`}, var_2) + -- fun_typesd: `%%`(decl*{decl <- `decl*`}, var_1) + -- fun_concat_idctxt: `%%`(I*{I <- `I*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecldots_(I : I) : (decl, idctxt)* diff --git a/spectec/test-middlend/specification.exp/09-sideconditions.il b/spectec/test-middlend/specification.exp/13-sideconditions.il similarity index 55% rename from spectec/test-middlend/specification.exp/09-sideconditions.il rename to spectec/test-middlend/specification.exp/13-sideconditions.il index 339eccbf92..68410057c1 100644 --- a/spectec/test-middlend/specification.exp/09-sideconditions.il +++ b/spectec/test-middlend/specification.exp/13-sideconditions.il @@ -22,23 +22,31 @@ def $min(nat : nat, nat : nat) : nat ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.1-9.56 -def $sum(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:10.1-10.18 - def $sum([]) = 0 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:11.1-11.35 - def $sum{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n + $sum(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 +relation fun_sum: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_0: + `%%`([], 0) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#1*{n'#1 <- `n'*`}, (n + var_0)) + -- fun_sum: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.1-13.57 -def $prod(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:14.1-14.19 - def $prod([]) = 1 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:15.1-15.37 - def $prod{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n * $prod(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 +relation fun_prod: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_0: + `%%`([], 1) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#2*{n'#2 <- `n'*`}, (n * var_0)) + -- fun_prod: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -58,7 +66,7 @@ def $concat_(syntax X, X**) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:15.1-15.34 def $concat_{syntax X}(syntax X, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:16.1-16.64 - def $concat_{syntax X, `w*` : X*, `w'**` : X**}(syntax X, [w*{w <- `w*`}] ++ w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) = w*{w <- `w*`} ++ $concat_(syntax X, w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) + def $concat_{syntax X, `w*` : X*, `w'**` : X**}(syntax X, [w#1*{w#1 <- `w*`}] ++ w'#1*{w'#1 <- `w'*#1`}*{`w'*#1` <- `w'**`}) = w*{w <- `w*`} ++ $concat_(syntax X, w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -69,7 +77,9 @@ def $concatn_(syntax X, X**, nat : nat) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w^n{w <- `w*`}] ++ w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2*{w#2 <- `w*`}] ++ w'#2*{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + -- if (n = |`w*`|) + -- (if (n = |`w'*#2`|))*{`w'*#2` <- `w'**`} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -77,7 +87,7 @@ def $concatopt_(syntax X, X?*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec def $concatopt_{syntax X}(syntax X, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $concatopt_{syntax X, `w?` : X?, `w'?*` : X?*}(syntax X, [w?{w <- `w?`}] ++ w'?{w' <- `w'?`}*{`w'?` <- `w'?*`}) = lift(w?{w <- `w?`}) ++ $concat_(syntax X, lift(w'?{w' <- `w'?`})*{`w'?` <- `w'?*`}) + def $concatopt_{syntax X, `w?` : X?, `w'?*` : X?*}(syntax X, [w#3?{w#3 <- `w?`}] ++ w'#3?{w'#3 <- `w'?#1`}*{`w'?#1` <- `w'?*`}) = lift(w?{w <- `w?`}) ++ $concat_(syntax X, lift(w'?{w' <- `w'?`})*{`w'?` <- `w'?*`}) ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec def $inv_concat_(syntax X, X*) : X** @@ -93,7 +103,7 @@ def $disjoint_(syntax X, X*) : bool ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:36.1-36.37 def $disjoint_{syntax X}(syntax X, []) = true ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:37.1-37.68 - def $disjoint_{syntax X, w : X, `w'*` : X*}(syntax X, [w] ++ w'*{w' <- `w'*`}) = (~ (w <- w'*{w' <- `w'*`}) /\ $disjoint_(syntax X, w'*{w' <- `w'*`})) + def $disjoint_{syntax X, w : X, `w'*` : X*}(syntax X, [w] ++ w'#4*{w'#4 <- `w'*`}) = (~ (w <- w'*{w' <- `w'*`}) /\ $disjoint_(syntax X, w'*{w' <- `w'*`})) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -104,7 +114,7 @@ def $setminus1_(syntax X, X : X, X*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:44.1-44.38 def $setminus1_{syntax X, w : X}(syntax X, w, []) = [w] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:45.1-45.78 - def $setminus1_{syntax X, w : X, w_1 : X, `w'*` : X*}(syntax X, w, [w_1] ++ w'*{w' <- `w'*`}) = (if (w = w_1) then [] else $setminus1_(syntax X, w, w'*{w' <- `w'*`})) + def $setminus1_{syntax X, w : X, w_1 : X, `w'*` : X*}(syntax X, w, [w_1] ++ w'#5*{w'#5 <- `w'*`}) = (if (w = w_1) then [] else $setminus1_(syntax X, w, w'*{w' <- `w'*`})) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -113,9 +123,9 @@ rec { ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:39.1-39.56 def $setminus_(syntax X, X*, X*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:42.1-42.40 - def $setminus_{syntax X, `w*` : X*}(syntax X, [], w*{w <- `w*`}) = [] + def $setminus_{syntax X, `w*` : X*}(syntax X, [], w#4*{w#4 <- `w*`}) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:43.1-43.90 - def $setminus_{syntax X, w_1 : X, `w'*` : X*, `w*` : X*}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}) = $setminus1_(syntax X, w_1, w*{w <- `w*`}) ++ $setminus_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}) + def $setminus_{syntax X, w_1 : X, `w'*` : X*, `w*` : X*}(syntax X, [w_1] ++ w'#6*{w'#6 <- `w'*`}, w#5*{w#5 <- `w*`}) = $setminus1_(syntax X, w_1, w*{w <- `w*`}) ++ $setminus_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -126,7 +136,7 @@ def $setproduct2_(syntax X, X : X, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:57.1-57.44 def $setproduct2_{syntax X, w_1 : X}(syntax X, w_1, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:58.1-58.90 - def $setproduct2_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, w_1, [w'*{w' <- `w'*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = [[w_1] ++ w'*{w' <- `w'*`}] ++ $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) + def $setproduct2_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, w_1, [w'#7*{w'#7 <- `w'*`}] ++ w#6*{w#6 <- `w*#1`}*{`w*#1` <- `w**`}) = [[w_1] ++ w'*{w' <- `w'*`}] ++ $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -135,9 +145,9 @@ rec { ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:50.1-50.47 def $setproduct1_(syntax X, X*, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:55.1-55.46 - def $setproduct1_{syntax X, `w**` : X**}(syntax X, [], w*{w <- `w*`}*{`w*` <- `w**`}) = [] + def $setproduct1_{syntax X, `w**` : X**}(syntax X, [], w#7*{w#7 <- `w*#2`}*{`w*#2` <- `w**`}) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:56.1-56.107 - def $setproduct1_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) ++ $setproduct1_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) + def $setproduct1_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, [w_1] ++ w'#8*{w'#8 <- `w'*`}, w#8*{w#8 <- `w*#3`}*{`w*#3` <- `w**`}) = $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) ++ $setproduct1_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -148,7 +158,7 @@ def $setproduct_(syntax X, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:53.1-53.40 def $setproduct_{syntax X}(syntax X, []) = [[]] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:54.1-54.90 - def $setproduct_{syntax X, `w_1*` : X*, `w**` : X**}(syntax X, [w_1*{w_1 <- `w_1*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct1_(syntax X, w_1*{w_1 <- `w_1*`}, $setproduct_(syntax X, w*{w <- `w*`}*{`w*` <- `w**`})) + def $setproduct_{syntax X, `w_1*` : X*, `w**` : X**}(syntax X, [w_1#1*{w_1#1 <- `w_1*`}] ++ w#9*{w#9 <- `w*#4`}*{`w*#4` <- `w**`}) = $setproduct1_(syntax X, w_1*{w_1 <- `w_1*`}, $setproduct_(syntax X, w*{w <- `w*`}*{`w*` <- `w**`})) } ;; ../../../../specification/wasm-3.0/1.0-syntax.profiles.spectec @@ -329,19 +339,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -381,44 +412,67 @@ relation wf_char: `%`(char) -- if (((i >= 0) /\ (i <= 55295)) \/ ((i >= 57344) /\ (i <= 1114111))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -def $cont(byte : byte) : nat +relation fun_cont: `%%`(byte, nat) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - def $cont{b : byte}(b) = ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat) + rule fun_cont_case_0{b : byte}: + `%%`(b, ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat)) -- if ((128 < $proj_byte_0(b).0) /\ ($proj_byte_0(b).0 < 192)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.1-91.25 -def $utf8(char*) : byte* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:52.1-52.44 - def $utf8{`ch*` : char*}(ch*{ch <- `ch*`}) = $concat_(syntax byte, $utf8([ch])*{ch <- `ch*`}) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:53.1-55.15 - def $utf8{ch : char}([ch]) = [b] +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation fun_utf8: `%%`(char*, byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_0{`ch*` : char*, `var_0*` : byte**}: + `%%`(ch#1*{ch#1 <- `ch*`}, $concat_(syntax byte, var_0*{var_0 <- `var_0*`})) + -- (fun_utf8: `%%`([ch], var_0))*{var_0 <- `var_0*`, ch <- `ch*`} + -- if (|`var_0*`| = |`ch*`|) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_1{ch : char}: + `%%`([ch], [b]) -- if ($proj_char_0(ch).0 < 128) -- let{b : byte} b = `%`_byte($proj_char_0(ch).0) -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:56.1-58.46 - def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_2{ch : char, b_1 : byte, b_2 : byte, var_0 : nat}: + `%%`([ch], [b_1 b_2]) -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) - -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] + -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + var_0)) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_3{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3]) -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) - -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] + -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * var_0)) + var_1)) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_4{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte, var_2 : nat, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3 b_4]) -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) - -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) + -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * var_0)) + ((2 ^ 6) * var_1)) + var_2)) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*, var_1 : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + -- fun_utf8: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -433,10 +487,11 @@ def $proj_name_0(x : name) : (char*) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_name: `%`(name) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule name_case_0{`char*` : char*}: + rule name_case_0{`char*` : char*, var_0 : byte*}: `%`(`%`_name(`char*`)) -- (wf_char: `%`(char))*{char <- `char*`} - -- if (|$utf8(char*{char <- `char*`})| < (2 ^ 32)) + -- if (|var_0| < (2 ^ 32)) + -- fun_utf8: `%%`(char*{char <- `char*`}, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax idx = u32 @@ -515,66 +570,101 @@ relation wf_externidx: `%`(externidx) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.1-129.86 -def $funcsxx(externidx*) : typeidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:135.1-135.24 - def $funcsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:136.1-136.45 - def $funcsxx{x : uN, `xx*` : externidx*}([FUNC_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $funcsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:137.1-137.58 - def $funcsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $funcsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 +relation fun_funcsxx: `%%`(externidx*, typeidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_1{x : uN, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([FUNC_externidx(x)] ++ xx#1*{xx#1 <- `xx*`}, [x] ++ var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([externidx] ++ xx#2*{xx#2 <- `xx*`}, var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.1-130.88 -def $globalsxx(externidx*) : globalidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:139.1-139.26 - def $globalsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:140.1-140.51 - def $globalsxx{x : uN, `xx*` : externidx*}([GLOBAL_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $globalsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:141.1-141.62 - def $globalsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $globalsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 +relation fun_globalsxx: `%%`(externidx*, globalidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_1{x : uN, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([GLOBAL_externidx(x)] ++ xx#3*{xx#3 <- `xx*`}, [x] ++ var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([externidx] ++ xx#4*{xx#4 <- `xx*`}, var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.1-131.87 -def $tablesxx(externidx*) : tableidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:143.1-143.25 - def $tablesxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:144.1-144.48 - def $tablesxx{x : uN, `xx*` : externidx*}([TABLE_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tablesxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:145.1-145.60 - def $tablesxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tablesxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 +relation fun_tablesxx: `%%`(externidx*, tableidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_1{x : uN, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([TABLE_externidx(x)] ++ xx#5*{xx#5 <- `xx*`}, [x] ++ var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([externidx] ++ xx#6*{xx#6 <- `xx*`}, var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.1-132.85 -def $memsxx(externidx*) : memidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:147.1-147.23 - def $memsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:148.1-148.42 - def $memsxx{x : uN, `xx*` : externidx*}([MEM_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $memsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:149.1-149.56 - def $memsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $memsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 +relation fun_memsxx: `%%`(externidx*, memidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_1{x : uN, `xx*` : externidx*, var_0 : memidx*}: + `%%`([MEM_externidx(x)] ++ xx#7*{xx#7 <- `xx*`}, [x] ++ var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : memidx*}: + `%%`([externidx] ++ xx#8*{xx#8 <- `xx*`}, var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.1-133.85 -def $tagsxx(externidx*) : tagidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:151.1-151.23 - def $tagsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:152.1-152.42 - def $tagsxx{x : uN, `xx*` : externidx*}([TAG_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tagsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:153.1-153.56 - def $tagsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tagsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 +relation fun_tagsxx: `%%`(externidx*, tagidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_1{x : uN, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([TAG_externidx(x)] ++ xx#9*{xx#9 <- `xx*`}, [x] ++ var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([externidx] ++ xx#10*{xx#10 <- `xx*`}, var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,81 +702,186 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation fun_free_list: `%%`(free*, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_0: + `%%`([], {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_1{free : free, `free'*` : free*, var_0 : free}: + `%%`([free] ++ free'#1*{free'#1 <- `free'*`}, free +++ var_0) + -- fun_free_list: `%%`(free'*{free' <- `free'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.1-173.29 -def $free_list(free*) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 - def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 - def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_list: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -701,6 +896,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -717,6 +921,10 @@ syntax numtype = | F32 | F64 +def $numtype_addrtype(addrtype) : numtype + def $numtype_addrtype(I32_addrtype) = I32_numtype + def $numtype_addrtype(I64_addrtype) = I64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax vectype = | V128 @@ -729,6 +937,12 @@ syntax consttype = | F64 | V128 +def $consttype_numtype(numtype) : consttype + def $consttype_numtype(I32_numtype) = I32_consttype + def $consttype_numtype(I64_numtype) = I64_consttype + def $consttype_numtype(F32_numtype) = F32_consttype + def $consttype_numtype(F64_numtype) = F64_consttype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax absheaptype = | ANY @@ -825,6 +1039,64 @@ syntax rectype = | REC(list(syntax subtype)) } +def $heaptype_absheaptype(absheaptype) : heaptype + def $heaptype_absheaptype(ANY_absheaptype) = ANY_heaptype + def $heaptype_absheaptype(EQ_absheaptype) = EQ_heaptype + def $heaptype_absheaptype(I31_absheaptype) = I31_heaptype + def $heaptype_absheaptype(STRUCT_absheaptype) = STRUCT_heaptype + def $heaptype_absheaptype(ARRAY_absheaptype) = ARRAY_heaptype + def $heaptype_absheaptype(NONE_absheaptype) = NONE_heaptype + def $heaptype_absheaptype(FUNC_absheaptype) = FUNC_heaptype + def $heaptype_absheaptype(NOFUNC_absheaptype) = NOFUNC_heaptype + def $heaptype_absheaptype(EXN_absheaptype) = EXN_heaptype + def $heaptype_absheaptype(NOEXN_absheaptype) = NOEXN_heaptype + def $heaptype_absheaptype(EXTERN_absheaptype) = EXTERN_heaptype + def $heaptype_absheaptype(NOEXTERN_absheaptype) = NOEXTERN_heaptype + def $heaptype_absheaptype(BOT_absheaptype) = BOT_heaptype + +def $valtype_addrtype(addrtype) : valtype + def $valtype_addrtype(I32_addrtype) = I32_valtype + def $valtype_addrtype(I64_addrtype) = I64_valtype + +def $storagetype_consttype(consttype) : storagetype + def $storagetype_consttype(I32_consttype) = I32_storagetype + def $storagetype_consttype(I64_consttype) = I64_storagetype + def $storagetype_consttype(F32_consttype) = F32_storagetype + def $storagetype_consttype(F64_consttype) = F64_storagetype + def $storagetype_consttype(V128_consttype) = V128_storagetype + +def $storagetype_numtype(numtype) : storagetype + def $storagetype_numtype(I32_numtype) = I32_storagetype + def $storagetype_numtype(I64_numtype) = I64_storagetype + def $storagetype_numtype(F32_numtype) = F32_storagetype + def $storagetype_numtype(F64_numtype) = F64_storagetype + +def $valtype_numtype(numtype) : valtype + def $valtype_numtype(I32_numtype) = I32_valtype + def $valtype_numtype(I64_numtype) = I64_valtype + def $valtype_numtype(F32_numtype) = F32_valtype + def $valtype_numtype(F64_numtype) = F64_valtype + +def $heaptype_typeuse(typeuse) : heaptype + def $heaptype_typeuse{x0 : typeidx}(_IDX_typeuse(x0)) = _IDX_heaptype(x0) + def $heaptype_typeuse{x0 : rectype, x1 : n}(_DEF_typeuse(x0, x1)) = _DEF_heaptype(x0, x1) + def $heaptype_typeuse{x0 : n}(REC_typeuse(x0)) = REC_heaptype(x0) + +def $storagetype_valtype(valtype) : storagetype + def $storagetype_valtype(I32_valtype) = I32_storagetype + def $storagetype_valtype(I64_valtype) = I64_storagetype + def $storagetype_valtype(F32_valtype) = F32_storagetype + def $storagetype_valtype(F64_valtype) = F64_storagetype + def $storagetype_valtype(V128_valtype) = V128_storagetype + def $storagetype_valtype{x0 : null?, x1 : heaptype}(REF_valtype(x0, x1)) = REF_storagetype(x0, x1) + def $storagetype_valtype(BOT_valtype) = BOT_storagetype + +def $storagetype_vectype(vectype) : storagetype + def $storagetype_vectype(V128_vectype) = V128_storagetype + +def $valtype_vectype(vectype) : valtype + def $valtype_vectype(V128_vectype) = V128_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { @@ -1015,11 +1287,21 @@ relation wf_subtype: `%`(subtype) syntax deftype = | _DEF(rectype : rectype, n : n) +def $heaptype_deftype(deftype) : heaptype + def $heaptype_deftype{x0 : rectype, x1 : n}(_DEF_deftype(x0, x1)) = _DEF_heaptype(x0, x1) + +def $typeuse_deftype(deftype) : typeuse + def $typeuse_deftype{x0 : rectype, x1 : n}(_DEF_deftype(x0, x1)) = _DEF_typeuse(x0, x1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax typevar = | _IDX(typeidx : typeidx) | REC(n : n) +def $typeuse_typevar(typevar) : typeuse + def $typeuse_typevar{x0 : typeidx}(_IDX_typevar(x0)) = _IDX_typeuse(x0) + def $typeuse_typevar{x0 : n}(REC_typevar(x0)) = REC_typeuse(x0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_typevar: `%`(typevar) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1035,6 +1317,12 @@ relation wf_typevar: `%`(typevar) syntax reftype = | REF(`null?` : null?, heaptype : heaptype) +def $storagetype_reftype(reftype) : storagetype + def $storagetype_reftype{x0 : null?, x1 : heaptype}(REF_reftype(x0, x1)) = REF_storagetype(x0, x1) + +def $valtype_reftype(reftype) : valtype + def $valtype_reftype{x0 : null?, x1 : heaptype}(REF_reftype(x0, x1)) = REF_valtype(x0, x1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_reftype: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1050,6 +1338,10 @@ syntax Fnn = | F32 | F64 +def $numtype_Fnn(Fnn) : numtype + def $numtype_Fnn(F32_Fnn) = F32_numtype + def $numtype_Fnn(F64_Fnn) = F64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Vnn = vectype @@ -1061,83 +1353,178 @@ syntax Cnn = | F64 | V128 +def $storagetype_Cnn(Cnn) : storagetype + def $storagetype_Cnn(I32_Cnn) = I32_storagetype + def $storagetype_Cnn(I64_Cnn) = I64_storagetype + def $storagetype_Cnn(F32_Cnn) = F32_storagetype + def $storagetype_Cnn(F64_Cnn) = F64_storagetype + def $storagetype_Cnn(V128_Cnn) = V128_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = | I8 | I16 +def $storagetype_packtype(packtype) : storagetype + def $storagetype_packtype(I8_packtype) = I8_storagetype + def $storagetype_packtype(I16_packtype) = I16_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax lanetype = | I32 @@ -1147,6 +1534,24 @@ syntax lanetype = | I8 | I16 +def $lanetype_Fnn(Fnn) : lanetype + def $lanetype_Fnn(F32_Fnn) = F32_lanetype + def $lanetype_Fnn(F64_Fnn) = F64_lanetype + +def $lanetype_addrtype(addrtype) : lanetype + def $lanetype_addrtype(I32_addrtype) = I32_lanetype + def $lanetype_addrtype(I64_addrtype) = I64_lanetype + +def $lanetype_numtype(numtype) : lanetype + def $lanetype_numtype(I32_numtype) = I32_lanetype + def $lanetype_numtype(I64_numtype) = I64_lanetype + def $lanetype_numtype(F32_numtype) = F32_lanetype + def $lanetype_numtype(F64_numtype) = F64_lanetype + +def $lanetype_packtype(packtype) : lanetype + def $lanetype_packtype(I8_packtype) = I8_lanetype + def $lanetype_packtype(I16_packtype) = I16_lanetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Pnn = packtype @@ -1157,6 +1562,16 @@ syntax Jnn = | I8 | I16 +def $lanetype_Jnn(Jnn) : lanetype + def $lanetype_Jnn(I32_Jnn) = I32_lanetype + def $lanetype_Jnn(I64_Jnn) = I64_lanetype + def $lanetype_Jnn(I8_Jnn) = I8_lanetype + def $lanetype_Jnn(I16_Jnn) = I16_lanetype + +def $Jnn_addrtype(addrtype) : Jnn + def $Jnn_addrtype(I32_addrtype) = I32_Jnn + def $Jnn_addrtype(I64_addrtype) = I64_Jnn + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Lnn = lanetype @@ -1319,35 +1734,51 @@ def $psize(packtype : packtype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lsize(lanetype : lanetype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{numtype : numtype}((numtype : numtype <: lanetype)) = $size(numtype) + def $lsize(I32_lanetype) = $size(I32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(I64_lanetype) = $size(I64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(F32_lanetype) = $size(F32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(F64_lanetype) = $size(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{packtype : packtype}((packtype : packtype <: lanetype)) = $psize(packtype) + def $lsize(I8_lanetype) = $psize(I8_packtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $zsize(storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{numtype : numtype}((numtype : numtype <: storagetype)) = ?($size(numtype)) + def $zsize(I32_storagetype) = ?($size(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(I64_storagetype) = ?($size(I64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(F32_storagetype) = ?($size(F32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{vectype : vectype}((vectype : vectype <: storagetype)) = ?($vsize(vectype)) + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{packtype : packtype}((packtype : packtype <: storagetype)) = ?($psize(packtype)) + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(I16_storagetype) = ?($psize(I16_packtype)) def $zsize{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $isize(Inn : Inn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $isize{Inn : addrtype}(Inn) = $size((Inn : addrtype <: numtype)) + def $isize{Inn : addrtype}(Inn) = $size($numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $jsize(Jnn : Jnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsize{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) + def $jsize{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $fsize(Fnn : Fnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $fsize{Fnn : Fnn}(Fnn) = $size((Fnn : Fnn <: numtype)) + def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_isize(nat : nat) : Inn? @@ -1365,7 +1796,7 @@ def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize{n : nat}(n) = (iter_val#1 : addrtype <: Jnn)?{iter_val#1 <- $inv_isize(n)} + def $inv_jsize{n : nat}(n) = $Jnn_addrtype(iter_val#1)?{iter_val#1 <- $inv_isize(n)} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_fsize(nat : nat) : Fnn? @@ -1419,7 +1850,7 @@ def $lsizenn2(lanetype : lanetype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $jsizenn(Jnn : Jnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsizenn{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) + def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_jsizenn(nat : nat) : Jnn? @@ -1429,443 +1860,1091 @@ def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{numtype : numtype}((numtype : numtype <: lanetype)) = numtype + def $lunpack(I32_lanetype) = I32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(I64_lanetype) = I64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(F32_lanetype) = F32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(F64_lanetype) = F64_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{packtype : packtype}((packtype : packtype <: lanetype)) = I32_numtype + def $lunpack(I8_lanetype) = I32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(I16_lanetype) = I32_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(storagetype : storagetype) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype + def $unpack(BOT_storagetype) = BOT_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack{`null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype)) = REF_valtype(`null?`, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(V128_storagetype) = V128_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(F64_storagetype) = F64_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(F32_storagetype) = F32_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I64_storagetype) = I64_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I32_storagetype) = I32_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I8_storagetype) = I32_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + def $unpack(I16_storagetype) = I32_valtype + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{numtype : numtype}((numtype : numtype <: storagetype)) = ?(numtype) + def $nunpack(I32_storagetype) = ?(I32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(I64_storagetype) = ?(I64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(F32_storagetype) = ?(F32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(F64_storagetype) = ?(F64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(I8_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_numtype) + def $nunpack(I16_storagetype) = ?(I32_numtype) def $nunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $vunpack(storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack{vectype : vectype}((vectype : vectype <: storagetype)) = ?(vectype) + def $vunpack(V128_storagetype) = ?(V128_vectype) def $vunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $cunpack(storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{consttype : consttype}((consttype : consttype <: storagetype)) = ?(consttype) + def $cunpack(I32_storagetype) = ?(I32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I64_storagetype) = ?(I64_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F32_storagetype) = ?(F32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F64_storagetype) = ?(F64_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(V128_storagetype) = ?(V128_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I8_storagetype) = ?(I32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I16_storagetype) = ?(I32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_consttype) + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{lanetype : lanetype}((lanetype : lanetype <: storagetype)) = ?(($lunpack(lanetype) : numtype <: consttype)) + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I16_storagetype) = ?($consttype_numtype($lunpack(I16_lanetype))) def $cunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $minat{at_1 : addrtype, at_2 : addrtype}(at_1, at_2) = (if ($size((at_1 : addrtype <: numtype)) <= $size((at_2 : addrtype <: numtype))) then at_1 else at_2) + def $minat{at_1 : addrtype, at_2 : addrtype}(at_1, at_2) = (if ($size($numtype_addrtype(at_1)) <= $size($numtype_addrtype(at_2))) then at_1 else at_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) + def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#1?{null_1#1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#2?{null_1#2 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $as_deftype{dt : deftype}((dt : deftype <: typeuse)) = ?(dt) + def $as_deftype{rectype : rectype, n : n}(_DEF_typeuse(rectype, n)) = ?(_DEF_deftype(rectype, n)) def $as_deftype{x0 : typeuse}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.1-308.87 -def $tagsxt(externtype*) : tagtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:314.1-314.23 - def $tagsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:315.1-315.44 - def $tagsxt{jt : typeuse, `xt*` : externtype*}([TAG_externtype(jt)] ++ xt*{xt <- `xt*`}) = [jt] ++ $tagsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:316.1-316.57 - def $tagsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tagsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 +relation fun_tagsxt: `%%`(externtype*, tagtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_1{jt : typeuse, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([TAG_externtype(jt)] ++ xt#1*{xt#1 <- `xt*`}, [jt] ++ var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([externtype] ++ xt#2*{xt#2 <- `xt*`}, var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.1-309.90 -def $globalsxt(externtype*) : globaltype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:318.1-318.26 - def $globalsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:319.1-319.53 - def $globalsxt{gt : globaltype, `xt*` : externtype*}([GLOBAL_externtype(gt)] ++ xt*{xt <- `xt*`}) = [gt] ++ $globalsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:320.1-320.63 - def $globalsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $globalsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation fun_globalsxt: `%%`(externtype*, globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_1{gt : globaltype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([GLOBAL_externtype(gt)] ++ xt#3*{xt#3 <- `xt*`}, [gt] ++ var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([externtype] ++ xt#4*{xt#4 <- `xt*`}, var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 -def $memsxt(externtype*) : memtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 - def $memsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:323.1-323.44 - def $memsxt{mt : memtype, `xt*` : externtype*}([MEM_externtype(mt)] ++ xt*{xt <- `xt*`}) = [mt] ++ $memsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:324.1-324.57 - def $memsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $memsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*, var_1 : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 -def $tablesxt(externtype*) : tabletype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 - def $tablesxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:327.1-327.50 - def $tablesxt{tt : tabletype, `xt*` : externtype*}([TABLE_externtype(tt)] ++ xt*{xt <- `xt*`}) = [tt] ++ $tablesxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:328.1-328.61 - def $tablesxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tablesxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation fun_memsxt: `%%`(externtype*, memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_1{mt : memtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([MEM_externtype(mt)] ++ xt#5*{xt#5 <- `xt*`}, [mt] ++ var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([externtype] ++ xt#6*{xt#6 <- `xt*`}, var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 -def $funcsxt(externtype*) : deftype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 - def $funcsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:331.1-331.47 - def $funcsxt{dt : deftype, `xt*` : externtype*}([FUNC_externtype((dt : deftype <: typeuse))] ++ xt*{xt <- `xt*`}) = [dt] ++ $funcsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:332.1-332.59 - def $funcsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $funcsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*, var_1 : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.1-337.126 -def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:365.1-365.38 - def $subst_typevar{tv : typevar}(tv, [], []) = ?((tv : typevar <: typeuse)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:366.1-366.95 - def $subst_typevar{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*}(tv, [tv_1] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`}) = (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- $subst_typevar(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})} - def $subst_typevar{x0 : typevar, x1 : typevar*, x2 : typeuse*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation fun_tablesxt: `%%`(externtype*, tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_1{tt : tabletype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([TABLE_externtype(tt)] ++ xt#7*{xt#7 <- `xt*`}, [tt] ++ var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([externtype] ++ xt#8*{xt#8 <- `xt*`}, var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*, var_1 : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesxt: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 +relation fun_funcsxt: `%%`(externtype*, deftype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_1{rectype : rectype, n : n, `xt*` : externtype*, var_0 : deftype*}: + `%%`([FUNC_externtype(_DEF_typeuse(rectype, n))] ++ xt#9*{xt#9 <- `xt*`}, [_DEF_deftype(rectype, n)] ++ var_0) + -- fun_funcsxt: `%%`(xt#10*{xt#10 <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : deftype*}: + `%%`([externtype] ++ xt#11*{xt#11 <- `xt*`}, var_0) + -- fun_funcsxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(typevar, typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%`(tv, [], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation fun_subst_typevar: `%%%%`(typevar, typevar*, typeuse*, typeuse?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%%`(tv, [], [], ?($typeuse_typevar(tv))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}, (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- var_0}) + -- fun_subst_typevar: `%%%%`(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_2{x0 : typevar, x1 : typevar*, x2 : typeuse*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse?}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typevar: `%%%%`(typevar, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:403.1-403.63 - def $minus_recs{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([REC_typevar(n)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + def $minus_recs{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 - def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) + def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#2*{tv'#2 <- `tv'*`}, tu'#2*{tu'#2 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`})) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- if ($minus_recs(var_0, var_1) =/= ?()) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_packtype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = pt + def $subst_packtype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}(pt, tv#4*{tv#4 <- `tv*`}, tu#4*{tu#4 <- `tu*`}) = pt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_numtype(numtype : numtype, typevar*, typeuse*) : numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_numtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = nt + def $subst_numtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}(nt, tv#5*{tv#5 <- `tv*`}, tu#5*{tu#5 <- `tu*`}) = nt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_vectype(vectype : vectype, typevar*, typeuse*) : vectype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_vectype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = vt + def $subst_vectype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}(vt, tv#6*{tv#6 <- `tv*`}, tu#6*{tu#6 <- `tu*`}) = vt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.1-338.112 -def $subst_typeuse(typeuse : typeuse, typevar*, typeuse*) : typeuse - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = !($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:370.1-370.64 - def $subst_typeuse{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.1-343.112 -def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = (!($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) : typeuse <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:377.1-377.65 - def $subst_heaptype{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:378.1-378.53 - def $subst_heaptype{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ht - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.1-344.112 -def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 - def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 -def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}((nt : numtype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_numtype(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : numtype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}((vt : vectype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_vectype(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : vectype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation fun_subst_typeuse: `%%%%`(typeuse, typevar*, typeuse*, typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_typeuse(n), tv#7*{tv#7 <- `tv*`}, tu#7*{tu#7 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#8*{tv#8 <- `tv*`}, tu#8*{tu#8 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_typeuse(typeidx), tv#9*{tv#9 <- `tv*`}, tu#9*{tu#9 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#10*{tv#10 <- `tv*`}, tu#10*{tu#10 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_typeuse(rectype, n), tv#11*{tv#11 <- `tv*`}, tu#11*{tu#11 <- `tu*`}, $typeuse_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#12*{tv#12 <- `tv*`}, tu#12*{tu#12 <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation fun_subst_heaptype: `%%%%`(heaptype, typevar*, typeuse*, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_heaptype(n), tv#13*{tv#13 <- `tv*`}, tu#13*{tu#13 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#14*{tv#14 <- `tv*`}, tu#14*{tu#14 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_heaptype(typeidx), tv#15*{tv#15 <- `tv*`}, tu#15*{tu#15 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#16*{tv#16 <- `tv*`}, tu#16*{tu#16 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_heaptype(rectype, n), tv#17*{tv#17 <- `tv*`}, tu#17*{tu#17 <- `tu*`}, $heaptype_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#18*{tv#18 <- `tv*`}, tu#18*{tu#18 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_3{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(ht, tv#19*{tv#19 <- `tv*`}, tu#19*{tu#19 <- `tu*`}, ht) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation fun_subst_reftype: `%%%%`(reftype, typevar*, typeuse*, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule fun_subst_reftype_case_0{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : heaptype}: + `%%%%`(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}, REF_reftype(null?{null <- `null?`}, var_0)) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_0{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I32_valtype, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, $valtype_numtype($subst_numtype(I32_numtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_1{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I64_valtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}, $valtype_numtype($subst_numtype(I64_numtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_2{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F32_valtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}, $valtype_numtype($subst_numtype(F32_numtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_3{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F64_valtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}, $valtype_numtype($subst_numtype(F64_numtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_4{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(V128_valtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}, $valtype_vectype($subst_vectype(V128_vectype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_5{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(REF_valtype(`null?`, heaptype), tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_6{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(BOT_valtype, tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}, BOT_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation fun_subst_storagetype: `%%%%`(storagetype, typevar*, typeuse*, storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_0{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(BOT_storagetype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_1{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(REF_storagetype(`null?`, heaptype), tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_2{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(V128_storagetype, tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_3{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F64_storagetype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_4{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F32_storagetype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_5{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I64_storagetype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_6{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I32_storagetype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_7{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I8_storagetype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}, $storagetype_packtype($subst_packtype(I8_packtype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_8{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I16_storagetype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}, $storagetype_packtype($subst_packtype(I16_packtype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation fun_subst_fieldtype: `%%%%`(fieldtype, typevar*, typeuse*, fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule fun_subst_fieldtype_case_0{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_0{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + -- if (|`var_0*`| = |`ft*`|) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_1{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_2{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_1*` : valtype*, `var_0*` : valtype*}: + `%%%%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} + -- if (|`var_1*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} + -- if (|`var_0*`| = |`t_1*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation fun_subst_subtype: `%%%%`(subtype, typevar*, typeuse*, subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule fun_subst_subtype_case_0{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) + -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} + -- if (|`var_0*`| = |`tu'*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 +relation fun_subst_rectype: `%%%%`(rectype, typevar*, typeuse*, rectype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 + rule fun_subst_rectype_case_0{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#4*{tu'#4 <- `tu'*`}) = !($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`})) + -- if ($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}) =/= ?()) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} + -- if (|`var_0*`| = |`st*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 +relation fun_subst_deftype: `%%%%`(deftype, typevar*, typeuse*, deftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 + rule fun_subst_deftype_case_0{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*, var_0 : rectype}: + `%%%%`(_DEF_deftype(qt, i), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, _DEF_deftype(var_0, i)) + -- fun_subst_rectype: `%%%%`(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 -def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{t : valtype, `tv*` : typevar*, `tu*` : typeuse*}((t : valtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : valtype <: storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}((pt : packtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_packtype(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : packtype <: storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 -def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 -def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 -def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 -def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st*{st <- `st*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 -def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typeuse: `%%%%`(typeuse, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype, var_2 : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_heaptype: `%`(ret_val) + -- fun_subst_heaptype: `%%%%`(heaptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype, var_2 : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_reftype: `%`(ret_val) + -- fun_subst_reftype: `%%%%`(reftype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype, var_2 : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_valtype: `%`(ret_val) + -- fun_subst_valtype: `%%%%`(valtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype, var_2 : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_storagetype: `%`(ret_val) + -- fun_subst_storagetype: `%%%%`(storagetype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype, var_2 : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_fieldtype: `%`(ret_val) + -- fun_subst_fieldtype: `%%%%`(fieldtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype, var_2 : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_comptype: `%`(ret_val) + -- fun_subst_comptype: `%%%%`(comptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype, var_2 : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_subtype: `%`(ret_val) + -- fun_subst_subtype: `%%%%`(subtype, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = at + def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}) = at + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_tagtype: `%%%%`(tagtype, typevar*, typeuse*, tagtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_tagtype_case_0{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tagtype}: + `%%%%`(tu', tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype +relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#2?{mut#2 <- `mut?`}, t), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype, var_2 : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_globaltype: `%`(ret_val) + -- fun_subst_globaltype: `%%%%`(globaltype, var_0, var_1, var_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}) = `%%PAGE`_memtype(at, lim) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype +relation fun_subst_tabletype: `%%%%`(tabletype, typevar*, typeuse*, tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule fun_subst_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule subst_tabletype_is_wf_0{tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype, var_2 : tabletype}: + `%%%%`(tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_tabletype: `%`(ret_val) + -- fun_subst_tabletype: `%%%%`(tabletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_externtype: `%%%%`(externtype, typevar*, typeuse*, externtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule fun_subst_externtype_case_0{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `tu*`}, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) + rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(MEM_externtype(mt), tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `tu*`}, MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(valtype : valtype, typeuse*) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%->%`_moduletype(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} + -- if (|`var_1*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} + -- if (|`var_0*`| = |`xt_1*`|) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_tagtype(tagtype : tagtype, typeuse*) : tagtype +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_tagtype{jt : typeuse, n : nat, `tu*` : typeuse*, i : nat}(jt, tu^n{tu <- `tu*`}) = $subst_tagtype(jt, _IDX_typevar(`%`_typeidx(i))^(i%`_comptype(resulttype_1, resulttype_2)) = $free_resulttype(resulttype_1) +++ $free_resulttype(resulttype_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.1-491.34 -def $free_subtype(subtype : subtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:550.1-551.66 - def $free_subtype{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype}(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) = $free_list($free_typeuse(typeuse)*{typeuse <- `typeuse*`}) +++ $free_comptype(comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.1-492.34 -def $free_rectype(rectype : rectype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:553.1-553.70 - def $free_rectype{`subtype*` : subtype*}(REC_rectype(`%`_list(subtype*{subtype <- `subtype*`}))) = $free_list($free_subtype(subtype)*{subtype <- `subtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.1-520.34 -def $free_deftype(deftype : deftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:521.1-521.59 - def $free_deftype{rectype : rectype, n : nat}(_DEF_deftype(rectype, n)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation fun_free_heaptype: `%%`(heaptype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_0: + `%%`(ANY_heaptype, $free_absheaptype(ANY_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_1: + `%%`(EQ_heaptype, $free_absheaptype(EQ_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_2: + `%%`(I31_heaptype, $free_absheaptype(I31_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_3: + `%%`(STRUCT_heaptype, $free_absheaptype(STRUCT_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_4: + `%%`(ARRAY_heaptype, $free_absheaptype(ARRAY_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_5: + `%%`(NONE_heaptype, $free_absheaptype(NONE_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_6: + `%%`(FUNC_heaptype, $free_absheaptype(FUNC_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_7: + `%%`(NOFUNC_heaptype, $free_absheaptype(NOFUNC_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_8: + `%%`(EXN_heaptype, $free_absheaptype(EXN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_9: + `%%`(NOEXN_heaptype, $free_absheaptype(NOEXN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_10: + `%%`(EXTERN_heaptype, $free_absheaptype(EXTERN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_11: + `%%`(NOEXTERN_heaptype, $free_absheaptype(NOEXTERN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_12: + `%%`(BOT_heaptype, $free_absheaptype(BOT_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_13{n_0 : n, var_0 : free}: + `%%`(REC_heaptype(n_0), var_0) + -- fun_free_typeuse: `%%`(REC_typeuse(n_0), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_14{rectype : rectype, n : n, var_0 : free}: + `%%`(_DEF_heaptype(rectype, n), var_0) + -- fun_free_typeuse: `%%`(_DEF_typeuse(rectype, n), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_15{typeidx : typeidx, var_0 : free}: + `%%`(_IDX_heaptype(typeidx), var_0) + -- fun_free_typeuse: `%%`(_IDX_typeuse(typeidx), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation fun_free_reftype: `%%`(reftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule fun_free_reftype_case_0{`null?` : null?, heaptype : heaptype, var_0 : free}: + `%%`(REF_reftype(null#2?{null#2 <- `null?`}, heaptype), var_0) + -- fun_free_heaptype: `%%`(heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation fun_free_typeuse: `%%`(typeuse, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_0{n : n}: + `%%`(REC_typeuse(n), $free_typevar(REC_typevar(n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_1{typeidx : typeidx}: + `%%`(_IDX_typeuse(typeidx), $free_typevar(_IDX_typevar(typeidx))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_2{rectype : rectype, n : n, var_0 : free}: + `%%`(_DEF_typeuse(rectype, n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(rectype, n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation fun_free_valtype: `%%`(valtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_0: + `%%`(I32_valtype, $free_numtype(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_1: + `%%`(I64_valtype, $free_numtype(I64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_2: + `%%`(F32_valtype, $free_numtype(F32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_3: + `%%`(F64_valtype, $free_numtype(F64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_4: + `%%`(V128_valtype, $free_vectype(V128_vectype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_5{`null?` : null?, heaptype : heaptype, var_0 : free}: + `%%`(REF_valtype(`null?`, heaptype), var_0) + -- fun_free_reftype: `%%`(REF_reftype(`null?`, heaptype), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_6: + `%%`(BOT_valtype, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation fun_free_resulttype: `%%`(resulttype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule fun_free_resulttype_case_0{`valtype*` : valtype*, `var_1*` : free*, var_0 : free}: + `%%`(`%`_resulttype(valtype#502*{valtype#502 <- `valtype*`}), var_0) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `valtype*`} + -- if (|`var_1*`| = |`valtype*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation fun_free_storagetype: `%%`(storagetype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_0{var_0 : free}: + `%%`(BOT_storagetype, var_0) + -- fun_free_valtype: `%%`(BOT_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_1{`null?` : null?, heaptype : heaptype, var_0 : free}: + `%%`(REF_storagetype(`null?`, heaptype), var_0) + -- fun_free_valtype: `%%`(REF_valtype(`null?`, heaptype), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_2{var_0 : free}: + `%%`(V128_storagetype, var_0) + -- fun_free_valtype: `%%`(V128_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_3{var_0 : free}: + `%%`(F64_storagetype, var_0) + -- fun_free_valtype: `%%`(F64_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_4{var_0 : free}: + `%%`(F32_storagetype, var_0) + -- fun_free_valtype: `%%`(F32_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_5{var_0 : free}: + `%%`(I64_storagetype, var_0) + -- fun_free_valtype: `%%`(I64_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_6{var_0 : free}: + `%%`(I32_storagetype, var_0) + -- fun_free_valtype: `%%`(I32_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_7: + `%%`(I8_storagetype, $free_packtype(I8_packtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_8: + `%%`(I16_storagetype, $free_packtype(I16_packtype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation fun_free_fieldtype: `%%`(fieldtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule fun_free_fieldtype_case_0{`mut?` : mut?, storagetype : storagetype, var_0 : free}: + `%%`(`%%`_fieldtype(mut#3?{mut#3 <- `mut?`}, storagetype), var_0) + -- fun_free_storagetype: `%%`(storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation fun_free_comptype: `%%`(comptype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_0{`fieldtype*` : fieldtype*, `var_1*` : free*, var_0 : free}: + `%%`(STRUCT_comptype(`%`_list(fieldtype#1*{fieldtype#1 <- `fieldtype*`})), var_0) + -- (fun_free_fieldtype: `%%`(fieldtype, var_1))*{var_1 <- `var_1*`, fieldtype <- `fieldtype*`} + -- if (|`var_1*`| = |`fieldtype*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_1{fieldtype : fieldtype, var_0 : free}: + `%%`(ARRAY_comptype(fieldtype), var_0) + -- fun_free_fieldtype: `%%`(fieldtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_2{resulttype_1 : list(syntax valtype), resulttype_2 : list(syntax valtype), var_1 : free, var_0 : free}: + `%%`(`FUNC%->%`_comptype(resulttype_1, resulttype_2), var_0 +++ var_1) + -- fun_free_resulttype: `%%`(resulttype_2, var_1) + -- fun_free_resulttype: `%%`(resulttype_1, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation fun_free_subtype: `%%`(subtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule fun_free_subtype_case_0{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(SUB_subtype(final#2?{final#2 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(comptype, var_2) + -- (fun_free_typeuse: `%%`(typeuse, var_1))*{var_1 <- `var_1*`, typeuse <- `typeuse*`} + -- if (|`var_1*`| = |`typeuse*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation fun_free_rectype: `%%`(rectype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule fun_free_rectype_case_0{`subtype*` : subtype*, `var_1*` : free*, var_0 : free}: + `%%`(REC_rectype(`%`_list(subtype#5*{subtype#5 <- `subtype*`})), var_0) + -- (fun_free_subtype: `%%`(subtype, var_1))*{var_1 <- `var_1*`, subtype <- `subtype*`} + -- if (|`var_1*`| = |`subtype*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation fun_free_deftype: `%%`(deftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule fun_free_deftype_case_0{rectype : rectype, n : nat, var_0 : free}: + `%%`(_DEF_deftype(rectype, n), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation free_heaptype_is_wf: `%%`(heaptype : heaptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule free_heaptype_is_wf_0{heaptype : heaptype, ret_val : free, var_0 : free}: + `%%`(heaptype, ret_val) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_heaptype: `%%`(heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation free_reftype_is_wf: `%%`(reftype : reftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule free_reftype_is_wf_0{reftype : reftype, ret_val : free, var_0 : free}: + `%%`(reftype, ret_val) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation free_typeuse_is_wf: `%%`(typeuse : typeuse, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule free_typeuse_is_wf_0{typeuse : typeuse, ret_val : free, var_0 : free}: + `%%`(typeuse, ret_val) + -- wf_typeuse: `%`(typeuse) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation free_valtype_is_wf: `%%`(valtype : valtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule free_valtype_is_wf_0{valtype : valtype, ret_val : free, var_0 : free}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_valtype: `%%`(valtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation free_resulttype_is_wf: `%%`(resulttype : resulttype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule free_resulttype_is_wf_0{resulttype : resulttype, ret_val : free, var_0 : free}: + `%%`(resulttype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_resulttype: `%%`(resulttype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation free_storagetype_is_wf: `%%`(storagetype : storagetype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule free_storagetype_is_wf_0{storagetype : storagetype, ret_val : free, var_0 : free}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_storagetype: `%%`(storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation free_fieldtype_is_wf: `%%`(fieldtype : fieldtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule free_fieldtype_is_wf_0{fieldtype : fieldtype, ret_val : free, var_0 : free}: + `%%`(fieldtype, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_fieldtype: `%%`(fieldtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation free_comptype_is_wf: `%%`(comptype : comptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule free_comptype_is_wf_0{comptype : comptype, ret_val : free, var_0 : free}: + `%%`(comptype, ret_val) + -- wf_comptype: `%`(comptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_comptype: `%%`(comptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation free_subtype_is_wf: `%%`(subtype : subtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule free_subtype_is_wf_0{subtype : subtype, ret_val : free, var_0 : free}: + `%%`(subtype, ret_val) + -- wf_subtype: `%`(subtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_subtype: `%%`(subtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation free_rectype_is_wf: `%%`(rectype : rectype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule free_rectype_is_wf_0{rectype : rectype, ret_val : free, var_0 : free}: + `%%`(rectype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_rectype: `%%`(rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation free_deftype_is_wf: `%%`(deftype : deftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule free_deftype_is_wf_0{deftype : deftype, ret_val : free, var_0 : free}: + `%%`(deftype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_deftype: `%%`(deftype, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tagtype(tagtype : tagtype) : free +relation fun_free_tagtype: `%%`(tagtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tagtype_case_0{rectype : rectype, n : n, var_0 : free}: + `%%`(_DEF_tagtype(rectype, n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(rectype, n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tagtype_is_wf: `%%`(tagtype : tagtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tagtype_is_wf_0{tagtype : tagtype, ret_val : free, var_0 : free}: + `%%`(tagtype, ret_val) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tagtype: `%%`(tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_globaltype: `%%`(globaltype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{deftype : deftype}((deftype : deftype <: typeuse)) = $free_deftype(deftype) + rule fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_globaltype(globaltype : globaltype) : free +relation free_globaltype_is_wf: `%%`(globaltype : globaltype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_globaltype{`mut?` : mut?, valtype : valtype}(`%%`_globaltype(mut?{mut <- `mut?`}, valtype)) = $free_valtype(valtype) + rule free_globaltype_is_wf_0{globaltype : globaltype, ret_val : free, var_0 : free}: + `%%`(globaltype, ret_val) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_globaltype: `%%`(globaltype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_memtype(memtype : memtype) : free @@ -1967,38 +3346,118 @@ def $free_memtype(memtype : memtype) : free def $free_memtype{addrtype : addrtype, limits : limits}(`%%PAGE`_memtype(addrtype, limits)) = $free_addrtype(addrtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free +relation free_memtype_is_wf: `%%`(memtype : memtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_memtype_is_wf_0{memtype : memtype, ret_val : free}: + `%%`(memtype, ret_val) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $free_memtype(memtype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_tabletype: `%%`(tabletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tabletype{addrtype : addrtype, limits : limits, reftype : reftype}(`%%%`_tabletype(addrtype, limits, reftype)) = $free_addrtype(addrtype) +++ $free_reftype(reftype) + rule fun_free_tabletype_case_0{addrtype : addrtype, limits : limits, reftype : reftype, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), $free_addrtype(addrtype) +++ var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tabletype_is_wf: `%%`(tabletype : tabletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tabletype_is_wf_0{tabletype : tabletype, ret_val : free, var_0 : free}: + `%%`(tabletype, ret_val) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tabletype: `%%`(tabletype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(datatype : datatype) : free ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(OK_datatype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_elemtype(elemtype : elemtype) : free +relation free_datatype_is_wf: `%%`(datatype : datatype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_datatype_is_wf_0{datatype : datatype, ret_val : free}: + `%%`(datatype, ret_val) + -- if (ret_val = $free_datatype(datatype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_elemtype: `%%`(elemtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_elemtype_case_0{reftype : reftype, var_0 : free}: + `%%`(reftype, var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_elemtype_is_wf: `%%`(elemtype : elemtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) + rule free_elemtype_is_wf_0{elemtype : elemtype, ret_val : free, var_0 : free}: + `%%`(elemtype, ret_val) + -- wf_reftype: `%`(elemtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemtype: `%%`(elemtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_externtype(externtype : externtype) : free +relation fun_free_externtype: `%%`(externtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_externtype(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tagtype : typeuse}(TAG_externtype(tagtype)) = $free_tagtype(tagtype) + rule fun_free_externtype_case_1{globaltype : globaltype, var_0 : free}: + `%%`(GLOBAL_externtype(globaltype), var_0) + -- fun_free_globaltype: `%%`(globaltype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_2{memtype : memtype}: + `%%`(MEM_externtype(memtype), $free_memtype(memtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) + rule fun_free_externtype_case_3{tabletype : tabletype, var_0 : free}: + `%%`(TABLE_externtype(tabletype), var_0) + -- fun_free_tabletype: `%%`(tabletype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) + rule fun_free_externtype_case_4{typeuse : typeuse, var_0 : free}: + `%%`(FUNC_externtype(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_externtype_is_wf: `%%`(externtype : externtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) + rule free_externtype_is_wf_0{externtype : externtype, ret_val : free, var_0 : free}: + `%%`(externtype, ret_val) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_moduletype: `%%`(moduletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) + rule fun_free_moduletype_case_0{`externtype_1*` : externtype*, `externtype_2*` : externtype*, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(`%->%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`}), var_0 +++ var_2) + -- (fun_free_externtype: `%%`(externtype_2, var_3))*{var_3 <- `var_3*`, externtype_2 <- `externtype_2*`} + -- if (|`var_3*`| = |`externtype_2*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_externtype: `%%`(externtype_1, var_1))*{var_1 <- `var_1*`, externtype_1 <- `externtype_1*`} + -- if (|`var_1*`| = |`externtype_1*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_moduletype(moduletype : moduletype) : free +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_moduletype{`externtype_1*` : externtype*, `externtype_2*` : externtype*}(`%->%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free, var_0 : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_moduletype: `%%`(moduletype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = @@ -2010,14 +3469,14 @@ relation wf_num_: `%%`(numtype, num_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule num__case_0{numtype : numtype, Inn : Inn, var_x : iN}: `%%`(numtype, mk_num__0_num_(Inn, var_x)) - -- wf_uN: `%%`($size((Inn : addrtype <: numtype)), var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- wf_uN: `%%`($size($numtype_addrtype(Inn)), var_x) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule num__case_1{numtype : numtype, Fnn : Fnn, var_x : fN}: `%%`(numtype, mk_num__1_num_(Fnn, var_x)) - -- wf_fN: `%%`($sizenn((Fnn : Fnn <: numtype)), var_x) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- wf_fN: `%%`($sizenn($numtype_Fnn(Fnn)), var_x) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_num__0(var_x : num_) : iN? @@ -2048,19 +3507,19 @@ relation wf_lane_: `%%`(lanetype, lane_) rule lane__case_0{lanetype : lanetype, numtype : numtype, var_x : num_}: `%%`(lanetype, mk_lane__0_lane_(numtype, var_x)) -- wf_num_: `%%`(numtype, var_x) - -- if (lanetype = (numtype : numtype <: lanetype)) + -- if (lanetype = $lanetype_numtype(numtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lane__case_1{lanetype : lanetype, packtype : packtype, var_x : pack_}: `%%`(lanetype, mk_lane__1_lane_(packtype, var_x)) -- wf_uN: `%%`($psize(packtype), var_x) - -- if (lanetype = (packtype : packtype <: lanetype)) + -- if (lanetype = $lanetype_packtype(packtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lane__case_2{lanetype : lanetype, Jnn : Jnn, var_x : iN}: `%%`(lanetype, mk_lane__2_lane_(Jnn, var_x)) - -- wf_uN: `%%`($lsize((Jnn : Jnn <: lanetype)), var_x) - -- if (lanetype = (Jnn : Jnn <: lanetype)) + -- wf_uN: `%%`($lsize($lanetype_Jnn(Jnn)), var_x) + -- if (lanetype = $lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_lane__0(var_x : lane_) : num_? @@ -2098,19 +3557,19 @@ relation wf_lit_: `%%`(storagetype, lit_) rule lit__case_0{storagetype : storagetype, numtype : numtype, var_x : num_}: `%%`(storagetype, mk_lit__0_lit_(numtype, var_x)) -- wf_num_: `%%`(numtype, var_x) - -- if (storagetype = (numtype : numtype <: storagetype)) + -- if (storagetype = $storagetype_numtype(numtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lit__case_1{storagetype : storagetype, vectype : vectype, var_x : vec_}: `%%`(storagetype, mk_lit__1_lit_(vectype, var_x)) -- wf_uN: `%%`($vsize(vectype), var_x) - -- if (storagetype = (vectype : vectype <: storagetype)) + -- if (storagetype = $storagetype_vectype(vectype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lit__case_2{storagetype : storagetype, packtype : packtype, var_x : pack_}: `%%`(storagetype, mk_lit__2_lit_(packtype, var_x)) -- wf_uN: `%%`($psize(packtype), var_x) - -- if (storagetype = (packtype : packtype <: storagetype)) + -- if (storagetype = $storagetype_packtype(packtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_lit__0(var_x : lit_) : num_? @@ -2179,7 +3638,7 @@ relation wf_unop_Inn: `%%`(Inn, unop_Inn) rule unop_Inn_case_3{Inn : Inn, sz : sz}: `%%`(Inn, EXTEND_unop_Inn(sz)) -- wf_sz: `%`(sz) - -- if ($proj_sz_0(sz).0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax unop_Fnn = @@ -2202,12 +3661,12 @@ relation wf_unop_: `%%`(numtype, unop_) rule unop__case_0{numtype : numtype, Inn : Inn, var_x : unop_Inn}: `%%`(numtype, mk_unop__0_unop_(Inn, var_x)) -- wf_unop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule unop__case_1{numtype : numtype, Fnn : Fnn, var_x : unop_Fnn}: `%%`(numtype, mk_unop__1_unop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_unop__0(var_x : unop_) : unop_Inn? @@ -2258,12 +3717,12 @@ relation wf_binop_: `%%`(numtype, binop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule binop__case_0{numtype : numtype, Inn : Inn, var_x : binop_Inn}: `%%`(numtype, mk_binop__0_binop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule binop__case_1{numtype : numtype, Fnn : Fnn, var_x : binop_Fnn}: `%%`(numtype, mk_binop__1_binop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_binop__0(var_x : binop_) : binop_Inn? @@ -2292,7 +3751,7 @@ relation wf_testop_: `%%`(numtype, testop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule testop__case_0{numtype : numtype, Inn : Inn, var_x : testop_Inn}: `%%`(numtype, mk_testop__0_testop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_testop__0(var_x : testop_) : testop_Inn @@ -2327,12 +3786,12 @@ relation wf_relop_: `%%`(numtype, relop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule relop__case_0{numtype : numtype, Inn : Inn, var_x : relop_Inn}: `%%`(numtype, mk_relop__0_relop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule relop__case_1{numtype : numtype, Fnn : Fnn, var_x : relop_Fnn}: `%%`(numtype, mk_relop__1_relop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_relop__0(var_x : relop_) : relop_Inn? @@ -2358,12 +3817,12 @@ relation wf_cvtop__Inn_1_Inn_2: `%%%`(Inn, Inn, cvtop__Inn_1_Inn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Inn_2_case_0{Inn_1 : Inn, Inn_2 : Inn, sx : sx}: `%%%`(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) < $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) < $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Inn_2_case_1{Inn_1 : Inn, Inn_2 : Inn}: `%%%`(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) > $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) > $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Inn_1_Fnn_2 = @@ -2379,7 +3838,7 @@ relation wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn, Fnn, cvtop__Inn_1_Fnn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Fnn_2_case_1{Inn_1 : Inn, Fnn_2 : Fnn}: `%%%`(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) = $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) = $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Fnn_1_Inn_2 = @@ -2400,7 +3859,7 @@ relation wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn, Inn, cvtop__Fnn_1_Inn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Inn_2_case_2{Fnn_1 : Fnn, Inn_2 : Inn}: `%%%`(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) = $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Fnn_1_Fnn_2 = @@ -2412,12 +3871,12 @@ relation wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn, Fnn, cvtop__Fnn_1_Fnn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Fnn_2_case_0{Fnn_1 : Fnn, Fnn_2 : Fnn}: `%%%`(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) < $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) < $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Fnn_2_case_1{Fnn_1 : Fnn, Fnn_2 : Fnn}: `%%%`(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) > $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) > $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__ = @@ -2432,29 +3891,29 @@ relation wf_cvtop__: `%%%`(numtype, numtype, cvtop__) rule cvtop___case_0{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Inn_2 : Inn, var_x : cvtop__Inn_1_Inn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___0_cvtop__(Inn_1, Inn_2, var_x)) -- wf_cvtop__Inn_1_Inn_2: `%%%`(Inn_1, Inn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) + -- if (numtype_1 = $numtype_addrtype(Inn_1)) + -- if (numtype_2 = $numtype_addrtype(Inn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_1{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Fnn_2 : Fnn, var_x : cvtop__Inn_1_Fnn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___1_cvtop__(Inn_1, Fnn_2, var_x)) -- wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn_1, Fnn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) + -- if (numtype_1 = $numtype_addrtype(Inn_1)) + -- if (numtype_2 = $numtype_Fnn(Fnn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_2{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Inn_2 : Inn, var_x : cvtop__Fnn_1_Inn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___2_cvtop__(Fnn_1, Inn_2, var_x)) -- wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn_1, Inn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) + -- if (numtype_1 = $numtype_Fnn(Fnn_1)) + -- if (numtype_2 = $numtype_addrtype(Inn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_3{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Fnn_2 : Fnn, var_x : cvtop__Fnn_1_Fnn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, var_x)) -- wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn_1, Fnn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) + -- if (numtype_1 = $numtype_Fnn(Fnn_1)) + -- if (numtype_2 = $numtype_Fnn(Fnn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_cvtop___0(var_x : cvtop__) : cvtop__Inn_1_Inn_2? @@ -2516,7 +3975,15 @@ relation wf_shape: `%`(shape) def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -2543,7 +4010,7 @@ relation wf_ishape: `%`(ishape) rule ishape_case_0{Jnn : Jnn, shape : shape}: `%`(`%`_ishape(shape)) -- wf_shape: `%`(shape) - -- if ($lanetype(shape) = (Jnn : Jnn <: lanetype)) + -- if ($lanetype(shape) = $lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax bshape = @@ -2609,7 +4076,7 @@ relation wf_vunop_Jnn_M: `%%%`(Jnn, M, vunop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vunop_Jnn_M_case_2{Jnn : Jnn, M : M}: `%%%`(Jnn, M, POPCNT_vunop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 8) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 8) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vunop_Fnn_M = @@ -2632,12 +4099,12 @@ relation wf_vunop_: `%%`(shape, vunop_) rule vunop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vunop_Jnn_M}: `%%`(shape, mk_vunop__0_vunop_(Jnn, M, var_x)) -- wf_vunop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vunop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vunop_Fnn_M}: `%%`(shape, mk_vunop__1_vunop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vunop__0(var_x : vunop_) : vunop_Jnn_M? @@ -2679,42 +4146,42 @@ relation wf_vbinop_Jnn_M: `%%%`(Jnn, M, vbinop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_4{Jnn : Jnn, M : M}: `%%%`(Jnn, M, MUL_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) >= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) >= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_5{Jnn : Jnn, M : M}: `%%%`(Jnn, M, AVGRU_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_6{Jnn : Jnn, M : M}: `%%%`(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_7{Jnn : Jnn, M : M}: `%%%`(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_8{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, MIN_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 32) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_9{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, MAX_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 32) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vbinop_Fnn_M = @@ -2740,12 +4207,12 @@ relation wf_vbinop_: `%%`(shape, vbinop_) rule vbinop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vbinop_Jnn_M}: `%%`(shape, mk_vbinop__0_vbinop_(Jnn, M, var_x)) -- wf_vbinop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vbinop_Fnn_M}: `%%`(shape, mk_vbinop__1_vbinop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vbinop__0(var_x : vbinop_) : vbinop_Jnn_M? @@ -2780,12 +4247,12 @@ relation wf_vternop_: `%%`(shape, vternop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vternop_Jnn_M}: `%%`(shape, mk_vternop__0_vternop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vternop_Fnn_M}: `%%`(shape, mk_vternop__1_vternop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vternop__0(var_x : vternop_) : vternop_Jnn_M? @@ -2814,7 +4281,7 @@ relation wf_vtestop_: `%%`(shape, vtestop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vtestop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vtestop_Jnn_M}: `%%`(shape, mk_vtestop__0_vtestop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vtestop__0(var_x : vtestop_) : vtestop_Jnn_M @@ -2843,22 +4310,22 @@ relation wf_vrelop_Jnn_M: `%%%`(Jnn, M, vrelop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, LT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, GT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_4{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, LE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_5{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, GE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vrelop_Fnn_M = @@ -2880,12 +4347,12 @@ relation wf_vrelop_: `%%`(shape, vrelop_) rule vrelop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vrelop_Jnn_M}: `%%`(shape, mk_vrelop__0_vrelop_(Jnn, M, var_x)) -- wf_vrelop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vrelop_Fnn_M}: `%%`(shape, mk_vrelop__1_vrelop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vrelop__0(var_x : vrelop_) : vrelop_Jnn_M? @@ -2915,7 +4382,7 @@ relation wf_vshiftop_: `%%`(ishape, vshiftop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vshiftop__case_0{ishape : ishape, Jnn : Jnn, M : M, var_x : vshiftop_Jnn_M}: `%%`(ishape, mk_vshiftop__0_vshiftop_(Jnn, M, var_x)) - -- if (ishape = `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) + -- if (ishape = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vshiftop__0(var_x : vshiftop_) : vshiftop_Jnn_M @@ -2952,7 +4419,7 @@ relation wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextunop__Jnn ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextunop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)) - -- if ((16 <= (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) <= 32))) + -- if ((16 <= (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) /\ (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) <= 32))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextunop__ = @@ -2964,8 +4431,8 @@ relation wf_vextunop__: `%%%`(ishape, ishape, vextunop__) rule vextunop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextunop___0(var_x : vextunop__) : vextunop__Jnn_1_M_1_Jnn_2_M_2 @@ -2983,17 +4450,17 @@ relation wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextbinop__J ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) >= 16)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) >= 16)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_1{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_2{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 16)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 16)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextbinop__ = @@ -3005,8 +4472,8 @@ relation wf_vextbinop__: `%%%`(ishape, ishape, vextbinop__) rule vextbinop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextbinop___0(var_x : vextbinop__) : vextbinop__Jnn_1_M_1_Jnn_2_M_2 @@ -3022,7 +4489,7 @@ relation wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextternop_ ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextternop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((4 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) + -- if (((4 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextternop__ = @@ -3034,8 +4501,8 @@ relation wf_vextternop__: `%%%`(ishape, ishape, vextternop__) rule vextternop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextternop___0(var_x : vextternop__) : vextternop__Jnn_1_M_1_Jnn_2_M_2 @@ -3051,7 +4518,7 @@ relation wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vcvtop__Jnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) + -- if ($lsizenn2($lanetype_Jnn(Jnn_2)) = (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Jnn_1_M_1_Fnn_2_M_2 = @@ -3062,7 +4529,7 @@ relation wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn, M, Fnn, M, vcvtop__Jnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Jnn_1_M_1_Fnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, `half?` : half?, sx : sx}: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(`half?`, sx)) - -- if (((($sizenn2((Fnn_2 : Fnn <: numtype)) = $lsizenn1((Jnn_1 : Jnn <: lanetype))) /\ ($lsizenn1((Jnn_1 : Jnn <: lanetype)) = 32)) /\ (half?{half <- `half?`} = ?())) \/ (($sizenn2((Fnn_2 : Fnn <: numtype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (half?{half <- `half?`} = ?(LOW_half)))) + -- if (((($sizenn2($numtype_Fnn(Fnn_2)) = $lsizenn1($lanetype_Jnn(Jnn_1))) /\ ($lsizenn1($lanetype_Jnn(Jnn_1)) = 32)) /\ (half?{half <- `half?`} = ?())) \/ (($sizenn2($numtype_Fnn(Fnn_2)) = (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) /\ (half?{half <- `half?`} = ?(LOW_half)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Fnn_1_M_1_Jnn_2_M_2 = @@ -3074,12 +4541,12 @@ relation wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn, M, Jnn, M, vcvtop__Fnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) + -- if (((($sizenn1($numtype_Fnn(Fnn_1)) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $lsizenn2($lanetype_Jnn(Jnn_2)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) + -- if (((($sizenn1($numtype_Fnn(Fnn_1)) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $lsizenn2($lanetype_Jnn(Jnn_2)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Fnn_1_M_1_Fnn_2_M_2 = @@ -3091,12 +4558,12 @@ relation wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn, M, Fnn, M, vcvtop__Fnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, zero : zero}: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $sizenn2((Fnn_2 : Fnn <: numtype)))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $sizenn2($numtype_Fnn(Fnn_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M}: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2) - -- if ((2 * $sizenn1((Fnn_1 : Fnn <: numtype))) = $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ((2 * $sizenn1($numtype_Fnn(Fnn_1))) = $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__ = @@ -3111,29 +4578,29 @@ relation wf_vcvtop__: `%%%`(shape, shape, vcvtop__) rule vcvtop___case_0{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_1{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_2{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_3{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vcvtop___0(var_x : vcvtop__) : vcvtop__Jnn_1_M_1_Jnn_2_M_2? @@ -3188,7 +4655,7 @@ relation wf_loadop_Inn: `%%`(Inn, loadop_Inn) rule loadop_Inn_case_0{Inn : Inn, sz : sz, sx : sx}: `%%`(Inn, `%_%`_loadop_Inn(sz, sx)) -- wf_sz: `%`(sz) - -- if ($proj_sz_0(sz).0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax loadop_ = @@ -3200,7 +4667,7 @@ relation wf_loadop_: `%%`(numtype, loadop_) rule loadop__case_0{numtype : numtype, Inn : Inn, var_x : loadop_Inn}: `%%`(numtype, mk_loadop__0_loadop_(Inn, var_x)) -- wf_loadop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_loadop__0(var_x : loadop_) : loadop_Inn @@ -3217,7 +4684,7 @@ relation wf_storeop_Inn: `%%`(Inn, storeop_Inn) rule storeop_Inn_case_0{Inn : Inn, sz : sz}: `%%`(Inn, `%`_storeop_Inn(sz)) -- wf_sz: `%`(sz) - -- if ($proj_sz_0(sz).0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax storeop_ = @@ -3229,7 +4696,7 @@ relation wf_storeop_: `%%`(numtype, storeop_) rule storeop__case_0{numtype : numtype, Inn : Inn, var_x : storeop_Inn}: `%%`(numtype, mk_storeop__0_storeop_(Inn, var_x)) -- wf_storeop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_storeop__0(var_x : storeop_) : storeop_Inn @@ -3455,6 +4922,16 @@ syntax val = | `REF.HOST_ADDR`(hostaddr : hostaddr) | `REF.EXTERN`(ref : ref) +def $val_ref(ref) : val + def $val_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_val(x0) + def $val_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_val + def $val_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_val(x0) + def $val_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_val(x0) + def $val_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_val(x0) + def $val_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_val(x0) + def $val_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_val(x0) + def $val_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_val(x0) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_val: `%`(val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -3639,6 +5116,28 @@ syntax instr = | TRAP } +def $instr_ref(ref) : instr + def $instr_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_instr(x0) + def $instr_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_instr + def $instr_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_instr(x0) + def $instr_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_instr(x0) + def $instr_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_instr(x0) + def $instr_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_instr(x0) + def $instr_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_instr(x0) + def $instr_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_instr(x0) + +def $instr_val(val) : instr + def $instr_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_instr(x0, x1) + def $instr_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_instr(x0, x1) + def $instr_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_instr(x0) + def $instr_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_instr + def $instr_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_instr(x0) + def $instr_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_instr(x0) + def $instr_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_instr(x0) + def $instr_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_instr(x0) + def $instr_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_instr(x0) + def $instr_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_instr(x0) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -4198,8 +5697,8 @@ relation wf_instr: `%`(instr) `%`(VEXTRACT_LANE_instr(shape, `sx?`, laneidx)) -- wf_shape: `%`(shape) -- wf_uN: `%%`(8, laneidx) - -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) + -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_103{shape : shape, laneidx : laneidx}: @@ -4271,16 +5770,36 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) + def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_consttype(consttype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free @@ -4288,11 +5807,35 @@ def $free_shape(shape : shape) : free def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_free_blocktype: `%%`(blocktype, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_0{`valtype?` : valtype?, `var_0?` : free?}: + `%%`(_RESULT_blocktype(valtype#504?{valtype#504 <- `valtype?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_0))?{var_0 <- `var_0?`, valtype <- `valtype?`} + -- if ((`var_0?` = ?()) <=> (`valtype?` = ?())) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype?{valtype <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) + rule fun_free_blocktype_case_1{typeidx : uN}: + `%%`(_IDX_blocktype(typeidx), $free_typeidx(typeidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free, var_0 : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_blocktype: `%%`(blocktype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free @@ -4305,258 +5848,539 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 +relation fun_shift_labelidxs: `%%`(labelidx*, labelidx*) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_1{`labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}, var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_2{labelidx : uN, `labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}, [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.1-584.44 -def $shift_labelidxs(labelidx*) : labelidx* - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:585.1-585.32 - def $shift_labelidxs([]) = [] - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:586.1-586.66 - def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 - def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation fun_free_instr: `%%`(instr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_0: + `%%`(NOP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_1: + `%%`(UNREACHABLE_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_2: + `%%`(DROP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{`valtype*?` : valtype*?, `var_1*?` : free*?, `var_0?` : free?}: + `%%`(SELECT_instr(valtype#505*{valtype#505 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `valtype*`}?{`var_1*` <- `var_1*?`, `valtype*` <- `valtype*?`} + -- if ((`var_1*?` = ?()) <=> (`valtype*?` = ?())) + -- (if (|`var_1*`| = |`valtype*`|))?{`var_1*` <- `var_1*?`, `valtype*` <- `valtype*?`} + -- (fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0))?{`var_1*` <- `var_1*?`, var_0 <- `var_0?`} + -- if ((`var_1*?` = ?()) <=> (`var_0?` = ?())) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_4{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_5{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(LOOP_instr(blocktype, instr#2*{instr#2 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_6{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(`IF%%ELSE%`_instr(blocktype, instr_1#1*{instr_1#1 <- `instr_1*`}, instr_2#1*{instr_2#1 <- `instr_2*`}), var_0 +++ var_1 +++ var_2) + -- fun_free_block: `%%`(instr_2*{instr_2 <- `instr_2*`}, var_2) + -- fun_free_block: `%%`(instr_1*{instr_1 <- `instr_1*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_7{labelidx : uN}: + `%%`(BR_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN}: + `%%`(BR_IF_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ $free_labelidx(labelidx')) + -- fun_free_list: `%%`($free_labelidx(labelidx)*{labelidx <- `labelidx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN}: + `%%`(BR_ON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN}: + `%%`(BR_ON_NON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_12{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_13{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN}: + `%%`(CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_15{typeuse : typeuse, var_0 : free}: + `%%`(CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_16{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_17: + `%%`(RETURN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{funcidx : uN}: + `%%`(RETURN_CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_19{typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_20{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN}: + `%%`(THROW_instr(tagidx), $free_tagidx(tagidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_22: + `%%`(THROW_REF_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_23{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*, `var_3*` : free*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`}), var_0 +++ var_1 +++ var_2) + -- (fun_free_instr: `%%`(instr, var_3))*{var_3 <- `var_3*`, instr <- `instr*`} + -- if (|`var_3*`| = |`instr*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- fun_free_list: `%%`($free_catch(catch)*{catch <- `catch*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_24{numtype : numtype, numlit : num_}: + `%%`(CONST_instr(numtype, numlit), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_}: + `%%`(UNOP_instr(numtype, unop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_}: + `%%`(BINOP_instr(numtype, binop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_}: + `%%`(TESTOP_instr(numtype, testop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_}: + `%%`(RELOP_instr(numtype, relop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_29{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), $free_numtype(numtype_1) +++ $free_numtype(numtype_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN}: + `%%`(VCONST_instr(vectype, veclit), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop}: + `%%`(VVUNOP_instr(vectype, vvunop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop}: + `%%`(VVBINOP_instr(vectype, vvbinop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop}: + `%%`(VVTERNOP_instr(vectype, vvternop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop}: + `%%`(VVTESTOP_instr(vectype, vvtestop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_}: + `%%`(VUNOP_instr(shape, vunop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_}: + `%%`(VBINOP_instr(shape, vbinop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_}: + `%%`(VTERNOP_instr(shape, vternop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_}: + `%%`(VTESTOP_instr(shape, vtestop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_}: + `%%`(VRELOP_instr(shape, vrelop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape}: + `%%`(VBITMASK_instr(ishape), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_44{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_45{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_46{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_47{ishape_1 : ishape, ishape_2 : ishape, sx : sx}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_48{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), $free_shape(shape_1) +++ $free_shape(shape_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape}: + `%%`(VSPLAT_instr(shape), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_50{shape : shape, `sx?` : sx?, laneidx : uN}: + `%%`(VEXTRACT_LANE_instr(shape, sx#45969?{sx#45969 <- `sx?`}, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_52{heaptype : heaptype, var_0 : free}: + `%%`(`REF.NULL`_instr(heaptype), var_0) + -- fun_free_heaptype: `%%`(heaptype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_53: + `%%`(`REF.IS_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_54: + `%%`(`REF.AS_NON_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_55: + `%%`(`REF.EQ`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_56{reftype : reftype, var_0 : free}: + `%%`(`REF.TEST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_57{reftype : reftype, var_0 : free}: + `%%`(`REF.CAST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_58{funcidx : uN}: + `%%`(`REF.FUNC`_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_59: + `%%`(`REF.I31`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_60{sx : sx}: + `%%`(`I31.GET`_instr(sx), {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{typeidx : uN}: + `%%`(`STRUCT.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_63{`sx?` : sx?, typeidx : uN, u32 : uN}: + `%%`(`STRUCT.GET`_instr(sx#45970?{sx#45970 <- `sx?`}, typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN}: + `%%`(`ARRAY.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN}: + `%%`(`ARRAY.GET`_instr(sx#45971?{sx#45971 <- `sx?`}, typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN}: + `%%`(`ARRAY.SET`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_72: + `%%`(`ARRAY.LEN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{typeidx : uN}: + `%%`(`ARRAY.FILL`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_74{typeidx_1 : uN, typeidx_2 : uN}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_77: + `%%`(`EXTERN.CONVERT_ANY`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_78: + `%%`(`ANY.CONVERT_EXTERN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{localidx : uN}: + `%%`(`LOCAL.GET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN}: + `%%`(`LOCAL.SET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN}: + `%%`(`LOCAL.TEE`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN}: + `%%`(`GLOBAL.GET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN}: + `%%`(`GLOBAL.SET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN}: + `%%`(`TABLE.GET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN}: + `%%`(`TABLE.SET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN}: + `%%`(`TABLE.SIZE`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN}: + `%%`(`TABLE.GROW`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN}: + `%%`(`TABLE.FILL`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_89{tableidx_1 : uN, tableidx_2 : uN}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), $free_tableidx(tableidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN}: + `%%`(`ELEM.DROP`_instr(elemidx), $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_92{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_93{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_94{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_95{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_96{vectype : vectype, memidx : uN, memarg : memarg}: + `%%`(VSTORE_instr(vectype, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_97{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN}: + `%%`(`MEMORY.SIZE`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN}: + `%%`(`MEMORY.GROW`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN}: + `%%`(`MEMORY.FILL`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_101{memidx_1 : uN, memidx_2 : uN}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), $free_memidx(memidx_1) +++ $free_memidx(memidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), $free_memidx(memidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN}: + `%%`(`DATA.DROP`_instr(dataidx), $free_dataidx(dataidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation fun_free_block: `%%`(instr*, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule fun_free_block_case_0{`instr*` : instr*, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- let{free : free} free = var_1 + -- (fun_free_instr: `%%`(instr#5, var_2))*{var_2 <- `var_2*`, instr#5 <- `instr*`} + -- if (|`var_2*`| = |`instr*`|) + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_shift_labelidxs: `%%`(free.LABELS_free, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.1-420.30 -def $free_instr(instr : instr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 - def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 - def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 - def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(LOOP_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:442.1-443.79 - def $free_instr{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}(`IF%%ELSE%`_instr(blocktype, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) = $free_blocktype(blocktype) +++ $free_block(instr_1*{instr_1 <- `instr_1*`}) +++ $free_block(instr_2*{instr_2 <- `instr_2*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:445.1-445.56 - def $free_instr{labelidx : uN}(BR_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:446.1-446.59 - def $free_instr{labelidx : uN}(BR_IF_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:447.1-448.69 - def $free_instr{`labelidx*` : labelidx*, labelidx' : uN}(BR_TABLE_instr(labelidx*{labelidx <- `labelidx*`}, labelidx')) = $free_list($free_labelidx(labelidx)*{labelidx <- `labelidx*`}) +++ $free_labelidx(labelidx') - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:449.1-449.64 - def $free_instr{labelidx : uN}(BR_ON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:450.1-450.68 - def $free_instr{labelidx : uN}(BR_ON_NON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:451.1-452.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:453.1-454.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:456.1-456.55 - def $free_instr{funcidx : uN}(CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:457.1-457.59 - def $free_instr{typeuse : typeuse}(CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:458.1-459.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 - def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 - def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 - def $free_instr{typeuse : typeuse}(RETURN_CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:463.1-464.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(RETURN_CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:466.1-466.53 - def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 - def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 - def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 - def $free_instr{numtype : numtype, numlit : num_}(CONST_instr(numtype, numlit)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:472.1-472.60 - def $free_instr{numtype : numtype, unop : unop_}(UNOP_instr(numtype, unop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:473.1-473.62 - def $free_instr{numtype : numtype, binop : binop_}(BINOP_instr(numtype, binop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:474.1-474.64 - def $free_instr{numtype : numtype, testop : testop_}(TESTOP_instr(numtype, testop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:475.1-475.62 - def $free_instr{numtype : numtype, relop : relop_}(RELOP_instr(numtype, relop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:476.1-477.55 - def $free_instr{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}(CVTOP_instr(numtype_1, numtype_2, cvtop)) = $free_numtype(numtype_1) +++ $free_numtype(numtype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:479.1-479.64 - def $free_instr{vectype : vectype, veclit : uN}(VCONST_instr(vectype, veclit)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:480.1-480.64 - def $free_instr{vectype : vectype, vvunop : vvunop}(VVUNOP_instr(vectype, vvunop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:481.1-481.66 - def $free_instr{vectype : vectype, vvbinop : vvbinop}(VVBINOP_instr(vectype, vvbinop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:482.1-482.68 - def $free_instr{vectype : vectype, vvternop : vvternop}(VVTERNOP_instr(vectype, vvternop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:483.1-483.68 - def $free_instr{vectype : vectype, vvtestop : vvtestop}(VVTESTOP_instr(vectype, vvtestop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:484.1-484.56 - def $free_instr{shape : shape, vunop : vunop_}(VUNOP_instr(shape, vunop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:485.1-485.58 - def $free_instr{shape : shape, vbinop : vbinop_}(VBINOP_instr(shape, vbinop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:486.1-486.60 - def $free_instr{shape : shape, vternop : vternop_}(VTERNOP_instr(shape, vternop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:487.1-487.60 - def $free_instr{shape : shape, vtestop : vtestop_}(VTESTOP_instr(shape, vtestop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:488.1-488.58 - def $free_instr{shape : shape, vrelop : vrelop_}(VRELOP_instr(shape, vrelop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:489.1-489.64 - def $free_instr{ishape : ishape, vshiftop : vshiftop_}(VSHIFTOP_instr(ishape, vshiftop)) = $free_shape($proj_ishape_0(ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:490.1-490.55 - def $free_instr{ishape : ishape}(VBITMASK_instr(ishape)) = $free_shape($proj_ishape_0(ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:491.1-491.66 - def $free_instr{bshape : bshape, vswizzlop : vswizzlop_}(VSWIZZLOP_instr(bshape, vswizzlop)) = $free_shape($proj_bshape_0(bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:492.1-492.64 - def $free_instr{bshape : bshape, `laneidx*` : laneidx*}(VSHUFFLE_instr(bshape, laneidx*{laneidx <- `laneidx*`})) = $free_shape($proj_bshape_0(bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:493.1-494.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}(VEXTUNOP_instr(ishape_1, ishape_2, vextunop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:495.1-496.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:497.1-498.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:499.1-500.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, sx : sx}(VNARROW_instr(ishape_1, ishape_2, sx)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:501.1-502.47 - def $free_instr{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}(VCVTOP_instr(shape_1, shape_2, vcvtop)) = $free_shape(shape_1) +++ $free_shape(shape_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:503.1-503.51 - def $free_instr{shape : shape}(VSPLAT_instr(shape)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:504.1-504.70 - def $free_instr{shape : shape, `sx?` : sx?, laneidx : uN}(VEXTRACT_LANE_instr(shape, sx?{sx <- `sx?`}, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:505.1-505.66 - def $free_instr{shape : shape, laneidx : uN}(VREPLACE_LANE_instr(shape, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:507.1-507.62 - def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 - def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 - def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 - def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 - def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 - def $free_instr{reftype : reftype}(`REF.CAST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:513.1-513.59 - def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 - def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 - def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 - def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 - def $free_instr{typeidx : uN}(`STRUCT.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:520.1-520.69 - def $free_instr{`sx?` : sx?, typeidx : uN, u32 : uN}(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:521.1-521.65 - def $free_instr{typeidx : uN, u32 : uN}(`STRUCT.SET`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:523.1-523.60 - def $free_instr{typeidx : uN}(`ARRAY.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:524.1-524.68 - def $free_instr{typeidx : uN}(`ARRAY.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:525.1-525.70 - def $free_instr{typeidx : uN, u32 : uN}(`ARRAY.NEW_FIXED`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:526.1-527.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.NEW_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:528.1-529.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:530.1-530.64 - def $free_instr{`sx?` : sx?, typeidx : uN}(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:531.1-531.60 - def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 - def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 - def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 - def $free_instr{typeidx_1 : uN, typeidx_2 : uN}(`ARRAY.COPY`_instr(typeidx_1, typeidx_2)) = $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:536.1-537.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.INIT_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:538.1-539.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 - def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 - def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 - def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 - def $free_instr{localidx : uN}(`LOCAL.SET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:546.1-546.63 - def $free_instr{localidx : uN}(`LOCAL.TEE`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:548.1-548.67 - def $free_instr{globalidx : uN}(`GLOBAL.GET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:549.1-549.67 - def $free_instr{globalidx : uN}(`GLOBAL.SET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:551.1-551.63 - def $free_instr{tableidx : uN}(`TABLE.GET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:552.1-552.63 - def $free_instr{tableidx : uN}(`TABLE.SET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:553.1-553.64 - def $free_instr{tableidx : uN}(`TABLE.SIZE`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:554.1-554.64 - def $free_instr{tableidx : uN}(`TABLE.GROW`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:555.1-555.64 - def $free_instr{tableidx : uN}(`TABLE.FILL`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:556.1-557.59 - def $free_instr{tableidx_1 : uN, tableidx_2 : uN}(`TABLE.COPY`_instr(tableidx_1, tableidx_2)) = $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:558.1-559.53 - def $free_instr{tableidx : uN, elemidx : uN}(`TABLE.INIT`_instr(tableidx, elemidx)) = $free_tableidx(tableidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:560.1-560.60 - def $free_instr{elemidx : uN}(`ELEM.DROP`_instr(elemidx)) = $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:562.1-563.49 - def $free_instr{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}(LOAD_instr(numtype, loadop?{loadop <- `loadop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:564.1-565.49 - def $free_instr{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}(STORE_instr(numtype, storeop?{storeop <- `storeop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:566.1-567.49 - def $free_instr{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}(VLOAD_instr(vectype, vloadop?{vloadop <- `vloadop?`}, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:568.1-569.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:570.1-571.49 - def $free_instr{vectype : vectype, memidx : uN, memarg : memarg}(VSTORE_instr(vectype, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:572.1-573.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:574.1-574.59 - def $free_instr{memidx : uN}(`MEMORY.SIZE`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:575.1-575.59 - def $free_instr{memidx : uN}(`MEMORY.GROW`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:576.1-576.59 - def $free_instr{memidx : uN}(`MEMORY.FILL`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:577.1-578.51 - def $free_instr{memidx_1 : uN, memidx_2 : uN}(`MEMORY.COPY`_instr(memidx_1, memidx_2)) = $free_memidx(memidx_1) +++ $free_memidx(memidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:579.1-580.49 - def $free_instr{memidx : uN, dataidx : uN}(`MEMORY.INIT`_instr(memidx, dataidx)) = $free_memidx(memidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:581.1-581.60 - def $free_instr{dataidx : uN}(`DATA.DROP`_instr(dataidx)) = $free_dataidx(dataidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.1-421.31 -def $free_block(instr*) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:589.1-590.47 - def $free_block{`instr*` : instr*}(instr*{instr <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] - -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free, var_0 : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_instr: `%%`(instr, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_block: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_expr(expr : expr) : free +relation fun_free_expr: `%%`(expr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_expr_case_0{`instr*` : instr*, `var_1*` : free*, var_0 : free}: + `%%`(instr#6*{instr#6 <- `instr*`}, var_0) + -- (fun_free_instr: `%%`(instr, var_1))*{var_1 <- `var_1*`, instr <- `instr*`} + -- if (|`var_1*`| = |`instr*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) + rule free_expr_is_wf_0{expr : expr, ret_val : free, var_0 : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_expr: `%%`(expr, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = @@ -4744,19 +6568,55 @@ relation wf_module: `%`(module) -- (wf_start: `%`(start))?{start <- `start?`} ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_type(type : type) : free +relation fun_free_type: `%%`(type, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_type_case_0{rectype : rectype, var_0 : free}: + `%%`(TYPE_type(rectype), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free, var_0 : free}: + `%%`(type, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_type: `%%`(type, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_tag: `%%`(tag, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) + rule fun_free_tag_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_tag(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_tag(tag : tag) : free +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) + rule free_tag_is_wf_0{tag : tag, ret_val : free, var_0 : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tag: `%%`(tag, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_global(global : global) : free +relation fun_free_global: `%%`(global, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) + rule fun_free_global_case_0{globaltype : globaltype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(GLOBAL_global(globaltype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_globaltype: `%%`(globaltype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free, var_0 : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_global: `%%`(global, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free @@ -4764,48 +6624,152 @@ def $free_mem(mem : mem) : free def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_table: `%%`(table, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_table_case_0{tabletype : tabletype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(TABLE_table(tabletype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tabletype: `%%`(tabletype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{table : table, ret_val : free, var_0 : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_table: `%%`(table, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_local: `%%`(local, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) + rule fun_free_local_case_0{t : valtype, var_0 : free}: + `%%`(LOCAL_local(t), var_0) + -- fun_free_valtype: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_local(local : local) : free +relation free_local_is_wf: `%%`(local : local, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + rule free_local_is_wf_0{local : local, ret_val : free, var_0 : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_local: `%%`(local, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_func(func : func) : free +relation fun_free_func: `%%`(func, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_func_case_0{typeidx : uN, `local*` : local*, expr : instr*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), $free_typeidx(typeidx) +++ var_0 +++ var_2[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_2) + -- (fun_free_local: `%%`(local, var_1))*{var_1 <- `var_1*`, local <- `local*`} + -- if (|`var_1*`| = |`local*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_func_is_wf: `%%`(func : func, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_func_is_wf_0{func : func, ret_val : free, var_0 : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_func: `%%`(func, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_datamode: `%%`(datamode, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_datamode_case_0{memidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), $free_memidx(memidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] + rule fun_free_datamode_case_1: + `%%`(PASSIVE_datamode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free, var_0 : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_datamode: `%%`(datamode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_data: `%%`(data, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_data_case_0{`byte*` : byte*, datamode : datamode, var_0 : free}: + `%%`(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode), var_0) + -- fun_free_datamode: `%%`(datamode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(data : data) : free +relation free_data_is_wf: `%%`(data : data, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) + rule free_data_is_wf_0{data : data, ret_val : free, var_0 : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_data: `%%`(data, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elemmode(elemmode : elemmode) : free +relation fun_free_elemmode: `%%`(elemmode, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_0{tableidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), $free_tableidx(tableidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_1: + `%%`(PASSIVE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) + rule fun_free_elemmode_case_2: + `%%`(DECLARE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free, var_0 : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemmode: `%%`(elemmode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_elem: `%%`(elem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_elem_case_0{reftype : reftype, `expr*` : expr*, elemmode : elemmode, var_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode), var_0 +++ var_1 +++ var_3) + -- fun_free_elemmode: `%%`(elemmode, var_3) + -- (fun_free_expr: `%%`(expr, var_2))*{var_2 <- `var_2*`, expr <- `expr*`} + -- if (|`var_2*`| = |`expr*`|) + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_reftype: `%%`(reftype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elem(elem : elem) : free +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) + rule free_elem_is_wf_0{elem : elem, ret_val : free, var_0 : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elem: `%%`(elem, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(start : start) : free @@ -4813,9 +6777,30 @@ def $free_start(start : start) : free def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_import: `%%`(import, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_import_case_0{name_1 : name, name_2 : name, externtype : externtype, var_0 : free}: + `%%`(IMPORT_import(name_1, name_2, externtype), var_0) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) + rule free_import_is_wf_0{import : import, ret_val : free, var_0 : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_import: `%%`(import, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(export : export) : free @@ -4823,19 +6808,71 @@ def $free_export(export : export) : free def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_module: `%%`(module, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_module_case_0{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_17 : free, `var_16*` : free*, var_15 : free, `var_14*` : free*, var_13 : free, `var_12*` : free*, var_11 : free, `var_10*` : free*, var_9 : free, `var_8*` : free*, var_7 : free, var_6 : free, `var_5*` : free*, var_4 : free, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`})), var_0 +++ var_2 +++ var_4 +++ var_6 +++ var_7 +++ var_9 +++ var_11 +++ var_13 +++ $free_opt($free_start(start)?{start <- `start?`}) +++ var_15 +++ var_17) + -- fun_free_list: `%%`($free_export(export)*{export <- `export*`}, var_17) + -- (fun_free_import: `%%`(import, var_16))*{var_16 <- `var_16*`, import <- `import*`} + -- if (|`var_16*`| = |`import*`|) + -- fun_free_list: `%%`(var_16*{var_16 <- `var_16*`}, var_15) + -- (fun_free_elem: `%%`(elem, var_14))*{var_14 <- `var_14*`, elem <- `elem*`} + -- if (|`var_14*`| = |`elem*`|) + -- fun_free_list: `%%`(var_14*{var_14 <- `var_14*`}, var_13) + -- (fun_free_data: `%%`(data, var_12))*{var_12 <- `var_12*`, data <- `data*`} + -- if (|`var_12*`| = |`data*`|) + -- fun_free_list: `%%`(var_12*{var_12 <- `var_12*`}, var_11) + -- (fun_free_func: `%%`(func, var_10))*{var_10 <- `var_10*`, func <- `func*`} + -- if (|`var_10*`| = |`func*`|) + -- fun_free_list: `%%`(var_10*{var_10 <- `var_10*`}, var_9) + -- (fun_free_table: `%%`(table, var_8))*{var_8 <- `var_8*`, table <- `table*`} + -- if (|`var_8*`| = |`table*`|) + -- fun_free_list: `%%`(var_8*{var_8 <- `var_8*`}, var_7) + -- fun_free_list: `%%`($free_mem(mem)*{mem <- `mem*`}, var_6) + -- (fun_free_global: `%%`(global, var_5))*{var_5 <- `var_5*`, global <- `global*`} + -- if (|`var_5*`| = |`global*`|) + -- fun_free_list: `%%`(var_5*{var_5 <- `var_5*`}, var_4) + -- (fun_free_tag: `%%`(tag, var_3))*{var_3 <- `var_3*`, tag <- `tag*`} + -- if (|`var_3*`| = |`tag*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_type: `%%`(type, var_1))*{var_1 <- `var_1*`, type <- `type*`} + -- if (|`var_1*`| = |`type*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) + rule free_module_is_wf_0{module : module, ret_val : free, var_0 : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_module: `%%`(module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $funcidx_module(module : module) : funcidx* +relation fun_funcidx_module: `%%`(module, funcidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $funcidx_module{module : module}(module) = $free_module(module).FUNCS_free + rule fun_funcidx_module_case_0{module : module, var_0 : free}: + `%%`(module, var_0.FUNCS_free) + -- fun_free_module: `%%`(module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $dataidx_funcs(func*) : dataidx* +relation fun_dataidx_funcs: `%%`(func*, dataidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $dataidx_funcs{`func*` : func*}(func*{func <- `func*`}) = $free_list($free_func(func)*{func <- `func*`}).DATAS_free + rule fun_dataidx_funcs_case_0{`func*` : func*, `var_1*` : free*, var_0 : free}: + `%%`(func#2*{func#2 <- `func*`}, var_0.DATAS_free) + -- (fun_free_func: `%%`(func, var_1))*{var_1 <- `var_1*`, func <- `func*`} + -- if (|`var_1*`| = |`func*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax init = @@ -4896,60 +6933,147 @@ relation wf_context: `%`(context) -- (wf_uN: `%%`(32, var_11))*{var_11 <- var_11} -- (wf_subtype: `%`(var_12))*{var_12 <- var_12} +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_with_locals_before_fun_with_locals_case_2: `%%%`(context, localidx*, localtype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_0{C : context}: + `%%%`(C, [], []) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.1-49.158 -def $with_locals(context : context, localidx*, localtype*) : context? - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:51.1-51.34 - def $with_locals{C : context}(C, [], []) = ?(C) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:52.1-52.90 - def $with_locals{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*}(C, [x_1] ++ x*{x <- `x*`}, [lct_1] ++ lct*{lct <- `lct*`}) = $with_locals(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}) - def $with_locals{x0 : context, x1 : localidx*, x2 : localtype*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation fun_with_locals: `%%%%`(context, localidx*, localtype*, context?) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_0{C : context}: + `%%%%`(C, [], [], ?(C)) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}, var_0) + -- fun_with_locals: `%%%%`(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}, var_0) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_2{x0 : context, x1 : localidx*, x2 : localtype*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_with_locals_before_fun_with_locals_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context, var_2 : context?}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_context: `%`(ret_val) + -- fun_with_locals: `%%%%`(context, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 -def $clos_deftypes(deftype*) : deftype* - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 - def $clos_deftypes([]) = [] - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:72.1-72.101 - def $clos_deftypes{`dt*` : deftype*, dt_n : deftype}(dt*{dt <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, (dt' : deftype <: typeuse)*{dt' <- `dt'*`})] - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(dt*{dt <- `dt*`}) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 +relation fun_clos_deftypes: `%%`(deftype*, deftype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- let{`dt'*` : deftype*} dt'#1*{dt'#1 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_valtype(context : context, valtype : valtype) : valtype +relation fun_clos_valtype: `%%%`(context, valtype, valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_valtype_case_0{C : context, t : valtype, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_clos_valtype: `%%%`(context, valtype, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_deftype: `%%%`(context, deftype, deftype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_deftype_case_0{C : context, dt : deftype, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- let{`dt'*` : deftype*} dt'#2*{dt'#2 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- let{`dt*` : deftype*} dt#5*{dt#5 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype}(C, dt) = $subst_all_deftype(dt, (dt' : deftype <: typeuse)*{dt' <- `dt'*`}) - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_externtype_case_0{C : context, xt : externtype, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse}(C, jt) = $subst_all_tagtype(jt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype, var_0 : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_externtype: `%`(ret_val) + -- fun_clos_externtype: `%%%`(context, externtype, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype, var_0 : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_moduletype: `%`(ret_val) + -- fun_clos_moduletype: `%%%`(context, moduletype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -4993,10 +7117,12 @@ relation Numtype_sub: `%|-%<:%`(context, numtype, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Expand: `%~~%`(deftype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: + rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*, var_0 : subtype}: `%~~%`(deftype, comptype) - -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- fun_unrolldt: `%%`(deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5013,13 +7139,33 @@ def $before(typeuse : typeuse, nat : nat) : bool def $before{typeuse : typeuse, i : nat}(typeuse, i) = true ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $unrollht_(context : context, heaptype : heaptype) : subtype +relation fun_unrollht_: `%%%`(context, heaptype, subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, deftype : deftype}(C, (deftype : deftype <: heaptype)) = $unrolldt(deftype) + rule fun_unrollht__case_0{rectype : rectype, n : n, C : context, var_0 : subtype}: + `%%%`(C, _DEF_heaptype(rectype, n), var_0) + -- fun_unrolldt: `%%`(_DEF_deftype(rectype, n), var_0) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, typeidx : uN}(C, _IDX_heaptype(typeidx)) = $unrolldt(C.TYPES_context[$proj_uN_0(typeidx).0]) + rule fun_unrollht__case_1{C : context, typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(typeidx), var_0) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(typeidx).0], var_0) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule fun_unrollht__case_2{C : context, i : nat}: + `%%%`(C, REC_heaptype(i), C.RECS_context[i]) + -- if (i < |C.RECS_context|) + +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype, var_0 : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_subtype: `%`(ret_val) + -- fun_unrollht_: `%%%`(context, heaptype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5028,12 +7174,12 @@ rec { relation Heaptype_ok: `%|-%:OK`(context, heaptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:20.1-21.24 rule abs{C : context, absheaptype : absheaptype}: - `%|-%:OK`(C, (absheaptype : absheaptype <: heaptype)) + `%|-%:OK`(C, $heaptype_absheaptype(absheaptype)) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:23.1-25.35 rule typeuse{C : context, typeuse : typeuse}: - `%|-%:OK`(C, (typeuse : typeuse <: heaptype)) + `%|-%:OK`(C, $heaptype_typeuse(typeuse)) -- Typeuse_ok: `%|-%:OK`(C, typeuse) -- wf_context: `%`(C) -- wf_typeuse: `%`(typeuse) @@ -5057,19 +7203,19 @@ relation Reftype_ok: `%|-%:OK`(context, reftype) relation Valtype_ok: `%|-%:OK`(context, valtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:34.1-36.35 rule num{C : context, numtype : numtype}: - `%|-%:OK`(C, (numtype : numtype <: valtype)) + `%|-%:OK`(C, $valtype_numtype(numtype)) -- Numtype_ok: `%|-%:OK`(C, numtype) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:38.1-40.35 rule vec{C : context, vectype : vectype}: - `%|-%:OK`(C, (vectype : vectype <: valtype)) + `%|-%:OK`(C, $valtype_vectype(vectype)) -- Vectype_ok: `%|-%:OK`(C, vectype) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:42.1-44.35 rule ref{C : context, reftype : reftype}: - `%|-%:OK`(C, (reftype : reftype <: valtype)) + `%|-%:OK`(C, $valtype_reftype(reftype)) -- Reftype_ok: `%|-%:OK`(C, reftype) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype) @@ -5085,23 +7231,23 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 rule deftype{C : context, deftype : deftype}: - `%|-%:OK`(C, (deftype : deftype <: typeuse)) + `%|-%:OK`(C, $typeuse_deftype(deftype)) -- Deftype_ok: `%|-%:OK`(C, deftype) -- wf_context: `%`(C) @@ -5127,14 +7273,14 @@ relation Fieldtype_ok: `%|-%:OK`(context, fieldtype) relation Storagetype_ok: `%|-%:OK`(context, storagetype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:122.1-124.35 rule val{C : context, valtype : valtype}: - `%|-%:OK`(C, (valtype : valtype <: storagetype)) + `%|-%:OK`(C, $storagetype_valtype(valtype)) -- Valtype_ok: `%|-%:OK`(C, valtype) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:126.1-128.37 rule pack{C : context, packtype : packtype}: - `%|-%:OK`(C, (packtype : packtype <: storagetype)) + `%|-%:OK`(C, $storagetype_packtype(packtype)) -- Packtype_ok: `%|-%:OK`(C, packtype) -- wf_context: `%`(C) @@ -5165,19 +7311,23 @@ relation Comptype_ok: `%|-%:OK`(context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:97.1-97.126 relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:167.1-176.49 - rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**}: + rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- if (|`comptype'*`| = |`typeuse*`|) - -- if (|`comptype'*`| = |`typeuse'**`|) - -- (if ($unrollht_(C, (typeuse : typeuse <: heaptype)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} + -- (if (var_0 = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`typeuse'**`|) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- if (|`comptype'*`| = |`typeuse'**`|) + -- (fun_unrollht_: `%%%`(C, $heaptype_typeuse(typeuse), var_0))*{var_0 <- `var_0*`, typeuse <- `typeuse*`} + -- if (|`var_0*`| = |`typeuse*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) @@ -5205,14 +7355,15 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) -- if (i < n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- if (n = |`subtype*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} + -- if (|`ft_1*`| = |`ft_2*`|) -- wf_context: `%`(C) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) @@ -5237,19 +7388,23 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:103.1-103.107 relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:195.1-197.66 - rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype}: + rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype, var_1 : deftype, var_0 : deftype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) -- wf_context: `%`(C) + -- fun_clos_deftype: `%%%`(C, deftype_2, var_1) + -- fun_clos_deftype: `%%%`(C, deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:199.1-202.49 - rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: + rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat, var_0 : subtype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[i]), $heaptype_deftype(deftype_2)) -- if (i < |typeuse*{typeuse <- `typeuse*`}|) - -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) -- wf_context: `%`(C) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- fun_unrolldt: `%%`(deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) @@ -5300,7 +7455,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:41.1-43.42 rule struct{C : context, deftype : deftype, `fieldtype*` : fieldtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), STRUCT_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), STRUCT_heaptype) -- Expand: `%~~%`(deftype, STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) -- wf_context: `%`(C) -- wf_heaptype: `%`(STRUCT_heaptype) @@ -5308,7 +7463,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:45.1-47.40 rule array{C : context, deftype : deftype, fieldtype : fieldtype}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), ARRAY_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), ARRAY_heaptype) -- Expand: `%~~%`(deftype, ARRAY_comptype(fieldtype)) -- wf_context: `%`(C) -- wf_heaptype: `%`(ARRAY_heaptype) @@ -5316,7 +7471,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:49.1-51.42 rule func{C : context, deftype : deftype, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), FUNC_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), FUNC_heaptype) -- Expand: `%~~%`(deftype, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_heaptype: `%`(FUNC_heaptype) @@ -5324,15 +7479,15 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:53.1-55.46 rule def{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: heaptype), (deftype_2 : deftype <: heaptype)) + `%|-%<:%`(C, $heaptype_deftype(deftype_1), $heaptype_deftype(deftype_2)) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) - -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype), heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) @@ -5340,8 +7495,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0])) -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype)) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) @@ -5349,8 +7504,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) @@ -5359,8 +7514,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) @@ -5369,8 +7524,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(FUNC_heaptype) @@ -5378,13 +7533,13 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: - `%|-%<:%`(C, REC_heaptype(i), (typeuse*{typeuse <- `typeuse*`}[j] : typeuse <: heaptype)) - -- if (j < |typeuse*{typeuse <- `typeuse*`}|) - -- if (i < |C.RECS_context|) + `%|-%<:%`(C, REC_heaptype(i), $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[j])) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (j < |typeuse*{typeuse <- `typeuse*`}|) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 rule none{C : context, heaptype : heaptype}: @@ -5459,19 +7614,19 @@ relation Reftype_sub: `%|-%<:%`(context, reftype, reftype) relation Valtype_sub: `%|-%<:%`(context, valtype, valtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:114.1-116.46 rule num{C : context, numtype_1 : numtype, numtype_2 : numtype}: - `%|-%<:%`(C, (numtype_1 : numtype <: valtype), (numtype_2 : numtype <: valtype)) + `%|-%<:%`(C, $valtype_numtype(numtype_1), $valtype_numtype(numtype_2)) -- Numtype_sub: `%|-%<:%`(C, numtype_1, numtype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:118.1-120.46 rule vec{C : context, vectype_1 : vectype, vectype_2 : vectype}: - `%|-%<:%`(C, (vectype_1 : vectype <: valtype), (vectype_2 : vectype <: valtype)) + `%|-%<:%`(C, $valtype_vectype(vectype_1), $valtype_vectype(vectype_2)) -- Vectype_sub: `%|-%<:%`(C, vectype_1, vectype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:122.1-124.46 rule ref{C : context, reftype_1 : reftype, reftype_2 : reftype}: - `%|-%<:%`(C, (reftype_1 : reftype <: valtype), (reftype_2 : reftype <: valtype)) + `%|-%<:%`(C, $valtype_reftype(reftype_1), $valtype_reftype(reftype_2)) -- Reftype_sub: `%|-%<:%`(C, reftype_1, reftype_2) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype_1) @@ -5489,8 +7644,8 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- if (|`t_1*`| = |`t_2*`|) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (|`t_1*`| = |`t_2*`|) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} -- (wf_valtype: `%`(t_2))*{t_2 <- `t_2*`} @@ -5499,7 +7654,7 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:162.1-164.46 rule val{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, (valtype_1 : valtype <: storagetype), (valtype_2 : valtype <: storagetype)) + `%|-%<:%`(C, $storagetype_valtype(valtype_1), $storagetype_valtype(valtype_2)) -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype_1) @@ -5507,7 +7662,7 @@ relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:166.1-168.49 rule pack{C : context, packtype_1 : packtype, packtype_2 : packtype}: - `%|-%<:%`(C, (packtype_1 : packtype <: storagetype), (packtype_2 : packtype <: storagetype)) + `%|-%<:%`(C, $storagetype_packtype(packtype_1), $storagetype_packtype(packtype_2)) -- Packtype_sub: `%|-%<:%`(C, packtype_1, packtype_2) -- wf_context: `%`(C) @@ -5547,9 +7702,9 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} -- if (|`lct*`| = |`x*`|) -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} - -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- `lct*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -5558,7 +7713,7 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule deftype{deftype : deftype, C : context, comptype : comptype}: - `%~~_%%`((deftype : deftype <: typeuse), C, comptype) + `%~~_%%`($typeuse_deftype(deftype), C, comptype) -- Expand: `%~~%`(deftype, comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) @@ -5566,8 +7721,8 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5586,20 +7741,24 @@ relation wf_oktypeidx: `%`(oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**}: + rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- if (|`comptype'*`| = |`yy**`|) - -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} - -- (if ($unrolldt(C.TYPES_context[$proj_uN_0(x).0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} + -- (if (var_0 = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`yy**`|) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- if (|`comptype'*`| = |`yy**`|) + -- (fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(x).0], var_0))*{var_0 <- `var_0*`, x <- `x*`} + -- if (|`var_0*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5659,7 +7818,7 @@ relation Memtype_ok: `%|-%:OK`(context, memtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule _{C : context, addrtype : addrtype, limits : limits}: `%|-%:OK`(C, `%%PAGE`_memtype(addrtype, limits)) - -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size((addrtype : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size($numtype_addrtype(addrtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) -- wf_context: `%`(C) -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits)) @@ -5668,7 +7827,7 @@ relation Tabletype_ok: `%|-%:OK`(context, tabletype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule _{C : context, addrtype : addrtype, limits : limits, reftype : reftype}: `%|-%:OK`(C, `%%%`_tabletype(addrtype, limits, reftype)) - -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size((addrtype : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) + -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size($numtype_addrtype(addrtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) -- Reftype_ok: `%|-%:OK`(C, reftype) -- wf_context: `%`(C) -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits, reftype)) @@ -5720,11 +7879,12 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- if (|`t*`| = |`x*`|) -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} - -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -5752,7 +7912,7 @@ relation Limits_sub: `%|-%<:%`(context, limits, limits) relation Tagtype_sub: `%|-%<:%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule _{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: typeuse), (deftype_2 : deftype <: typeuse)) + `%|-%<:%`(C, $typeuse_deftype(deftype_1), $typeuse_deftype(deftype_2)) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- Deftype_sub: `%|-%<:%`(C, deftype_2, deftype_1) -- wf_context: `%`(C) @@ -5834,11 +7994,11 @@ relation Externtype_sub: `%|-%<:%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule func{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, FUNC_externtype((deftype_1 : deftype <: typeuse)), FUNC_externtype((deftype_2 : deftype <: typeuse))) + `%|-%<:%`(C, FUNC_externtype($typeuse_deftype(deftype_1)), FUNC_externtype($typeuse_deftype(deftype_2))) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- wf_context: `%`(C) - -- wf_externtype: `%`(FUNC_externtype((deftype_1 : deftype <: typeuse))) - -- wf_externtype: `%`(FUNC_externtype((deftype_2 : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_1))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_2))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) @@ -5853,8 +8013,8 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -5865,11 +8025,11 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -5877,11 +8037,11 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -5889,46 +8049,57 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) + def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0))))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + def $default_(F32_valtype) = ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(?(VCONST_val(Vnn, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) + def $default_(F64_valtype) = ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- if ($default_(valtype) =/= ?()) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%DEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -5936,13 +8107,13 @@ relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) rule _{n : n, m : m, at : addrtype, N : N}: `|-%:%->%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}, at, N) -- if (((2 ^ n) : nat <:> rat) <= ((N : nat <:> rat) / (8 : nat <:> rat))) - -- if (m < (2 ^ $size((at : addrtype <: numtype)))) + -- if (m < (2 ^ $size($numtype_addrtype(at)))) -- wf_memarg: `%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec def $is_packtype(storagetype : storagetype) : bool ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= ($unpack(zt) : valtype <: storagetype)) + def $is_packtype{zt : storagetype}(zt) = (zt =/= $storagetype_valtype($unpack(zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rec { @@ -5985,7 +8156,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, SELECT_instr(?()), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) -- Valtype_ok: `%|-%:OK`(C, t) -- Valtype_sub: `%|-%<:%`(C, t, t') - -- if ((t' = (numtype : numtype <: valtype)) \/ (t' = (vectype : vectype <: valtype))) + -- if ((t' = $valtype_numtype(numtype)) \/ (t' = $valtype_vectype(vectype))) -- wf_context: `%`(C) -- wf_valtype: `%`(t') -- wf_instr: `%`(SELECT_instr(?())) @@ -6030,8 +8201,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_instr(l)) @@ -6041,8 +8212,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, `t*` : valtype*}: `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) @@ -6050,10 +8221,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]))*{l <- `l*`} - -- if ($proj_uN_0(l').0 < |C.LABELS_context|) + -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l').0]) + -- if ($proj_uN_0(l').0 < |C.LABELS_context|) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) @@ -6062,8 +8233,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NULL_instr(l)) @@ -6072,17 +8243,17 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) + `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) @@ -6090,27 +8261,28 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) + `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6119,8 +8291,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6128,15 +8300,15 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: - `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6154,8 +8326,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) @@ -6169,8 +8341,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) @@ -6183,19 +8355,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: - `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) -- wf_context: `%`(C) -- (wf_valtype: `%`(t'_2))*{t'_2 <- `t'_2*`} -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6204,9 +8376,9 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(THROW_instr(x)) @@ -6245,14 +8417,14 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule `ref.func`{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) + `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) - -- if (|C.REFS_context| > 0) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (x <- C.REFS_context) + -- if (|C.REFS_context| > 0) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 rule `ref.i31`{C : context}: @@ -6286,23 +8458,23 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:225.1-229.33 rule `ref.test`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) -- wf_instr: `%`(`REF.TEST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:231.1-235.33 rule `ref.cast`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) -- wf_instr: `%`(`REF.CAST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:240.1-241.42 rule `i31.get`{C : context, sx : sx}: @@ -6314,8 +8486,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6324,10 +8496,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6335,10 +8508,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) + -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)) @@ -6349,10 +8522,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) + -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) @@ -6362,8 +8535,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6372,10 +8545,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6383,8 +8557,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6393,24 +8567,25 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6418,8 +8593,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)) @@ -6429,8 +8604,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule `array.set`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) @@ -6446,8 +8621,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule `array.fill`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) @@ -6456,10 +8631,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) + -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) + -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) @@ -6470,10 +8645,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), zt) -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) - -- Storagetype_sub: `%|-%<:%`(C, (C.ELEMS_context[$proj_uN_0(y).0] : reftype <: storagetype), zt) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) @@ -6482,12 +8657,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6511,8 +8687,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule `local.get`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -6521,8 +8697,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule `local.set`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) @@ -6531,8 +8707,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule `local.tee`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) @@ -6541,8 +8717,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -6551,8 +8727,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule `global.set`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) @@ -6560,87 +8736,87 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: - `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: - `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) + -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) + -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at_1, lim_1, rt_1)) -- wf_tabletype: `%`(`%%%`_tabletype(at_2, lim_2, rt_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) -- wf_reftype: `%`(rt_2) -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt_1)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule `elem.drop`{C : context, x : idx, rt : reftype}: `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) + -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) @@ -6648,232 +8824,232 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: - `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) + `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) + -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) + -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at_1, lim_1)) -- wf_memtype: `%`(`%%PAGE`_memtype(at_2, lim_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule `data.drop`{C : context, x : idx}: `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) + -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) - -- wf_instr: `%`(LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) + -- wf_instr: `%`(LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) - -- wf_instr: `%`(STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instr: `%`(STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) -- wf_context: `%`(C) -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:520.1-521.33 rule const{C : context, nt : numtype, c_nt : num_}: - `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CONST_instr(nt, c_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:523.1-524.34 rule unop{C : context, nt : numtype, unop_nt : unop_}: - `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(UNOP_instr(nt, unop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:526.1-527.39 rule binop{C : context, nt : numtype, binop_nt : binop_}: - `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr(nt, binop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:529.1-530.39 rule testop{C : context, nt : numtype, testop_nt : testop_}: - `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(TESTOP_instr(nt, testop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:532.1-533.40 rule relop{C : context, nt : numtype, relop_nt : relop_}: - `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(RELOP_instr(nt, relop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:535.1-536.44 rule cvtop{C : context, nt_1 : numtype, nt_2 : numtype, cvtop : cvtop__}: - `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) + `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CVTOP_instr(nt_1, nt_2, cvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:541.1-542.35 rule vconst{C : context, c : vec_}: @@ -6971,31 +9147,34 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 rule vsplat{C : context, sh : shape}: - `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSPLAT_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:587.1-589.21 rule vextract_lane{C : context, sh : shape, `sx?` : sx?, i : laneidx}: - `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) + `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 rule vreplace_lane{C : context, sh : shape, i : laneidx}: - `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:595.1-596.50 rule vextunop{C : context, sh_1 : ishape, sh_2 : ishape, vextunop : vextunop__}: @@ -7041,23 +9220,25 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:617.1-621.82 - rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} -- if (|`init*`| = |`t*`|) -- if (|`init*`| = |`x_1*`|) -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} - -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) - -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- Instrs_ok: `%|-%:%`(!(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- if (var_0 =/= ?()) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 rule sub{C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -7096,9 +9277,10 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7177,24 +9359,24 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule `global.get`{C : context, x : idx, t : valtype}: `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, Inn : Inn, binop : binop_}: - `%|-%CONST`(C, BINOP_instr((Inn : addrtype <: numtype), binop)) - -- if (|[I32_Inn I64_Inn]| > 0) + `%|-%CONST`(C, BINOP_instr($numtype_addrtype(Inn), binop)) -- if (Inn <- [I32_Inn I64_Inn]) - -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) + -- if (|[I32_Inn I64_Inn]| > 0) -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) + -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) -- wf_context: `%`(C) - -- wf_instr: `%`(BINOP_instr((Inn : addrtype <: numtype), binop)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn)) + -- wf_instr: `%`(BINOP_instr($numtype_addrtype(Inn), binop)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, ADD_binop_Inn)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, SUB_binop_Inn)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, MUL_binop_Inn)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Expr_const: `%|-%CONST`(context, expr) @@ -7219,23 +9401,26 @@ relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Type_ok: `%|-%:%`(context, type, deftype*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx}: + rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx, var_0 : deftype*}: `%|-%:%`(C, TYPE_type(rectype), dt*{dt <- `dt*`}) -- if ($proj_uN_0(x).0 = |C.TYPES_context|) - -- if (dt*{dt <- `dt*`} = $rolldt(x, rectype)) + -- if (dt*{dt <- `dt*`} = var_0) -- Rectype_ok: `%|-%:%`(C +++ {TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rectype, OK_oktypeidx(x)) -- wf_context: `%`(C) -- wf_context: `%`({TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_oktypeidx: `%`(OK_oktypeidx(x)) + -- fun_rolldt: `%%%`(x, rectype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Tag_ok: `%|-%:%`(context, tag, tagtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, tagtype : tagtype}: - `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) + rule _{C : context, tagtype : tagtype, var_0 : tagtype}: + `%|-%:%`(C, TAG_tag(tagtype), var_0) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`(var_0) -- wf_tag: `%`(TAG_tag(tagtype)) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7265,7 +9450,7 @@ relation Table_ok: `%|-%:%`(context, table, tabletype) `%|-%:%`(C, TABLE_table(tabletype, expr), tabletype) -- Tabletype_ok: `%|-%:OK`(C, tabletype) -- if (tabletype = `%%%`_tabletype(at, lim, rt)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (rt : reftype <: valtype)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(rt)) -- wf_context: `%`(C) -- wf_table: `%`(TABLE_table(tabletype, expr)) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -7293,10 +9478,10 @@ relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[$proj_uN_0(x).0]) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (|`lct*`| = |`local*`|) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} + -- if (|`lct*`| = |`local*`|) -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- wf_context: `%`(C) -- wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr)) @@ -7314,9 +9499,9 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -7349,10 +9534,10 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, rt') - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) @@ -7364,7 +9549,7 @@ relation Elem_ok: `%|-%:%`(context, elem, elemtype) rule _{C : context, elemtype : elemtype, `expr*` : expr*, elemmode : elemmode}: `%|-%:%`(C, ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode), elemtype) -- Reftype_ok: `%|-%:OK`(C, elemtype) - -- (Expr_ok_const: `%|-%:%CONST`(C, expr, (elemtype : reftype <: valtype)))*{expr <- `expr*`} + -- (Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(elemtype)))*{expr <- `expr*`} -- Elemmode_ok: `%|-%:%`(C, elemmode, elemtype) -- wf_context: `%`(C) -- wf_elem: `%`(ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode)) @@ -7374,8 +9559,8 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) @@ -7383,19 +9568,21 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Import_ok: `%|-%:%`(context, import, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, name_1 : name, name_2 : name, xt : externtype}: - `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) + rule _{C : context, name_1 : name, name_2 : name, xt : externtype, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`(var_0) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) @@ -7403,8 +9590,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) @@ -7412,8 +9599,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) @@ -7421,20 +9608,20 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype((dt : deftype <: typeuse))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) + `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) - -- wf_externtype: `%`(FUNC_externtype((dt : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Export_ok: `%|-%:%%`(context, export, name, externtype) @@ -7504,48 +9691,55 @@ relation wf_nonfuncs: `%`(nonfuncs) -- (wf_export: `%`(export))*{export <- `export*`} ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* +relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) + rule fun_funcidx_nonfuncs_case_0{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_0 : funcidx*}: + `%%`(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`}), var_0) + -- fun_funcidx_module: `%%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: - `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*, var_6 : deftype*, var_5 : tabletype*, var_4 : memtype*, var_3 : globaltype*, var_2 : tagtype*, var_1 : funcidx*, var_0 : moduletype}: + `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) - -- if (|`import*`| = |`xt_I*`|) -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} - -- if (|`jt*`| = |`tag*`|) + -- if (|`import*`| = |`xt_I*`|) -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} + -- if (|`jt*`| = |`tag*`|) -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) - -- if (|`mem*`| = |`mt*`|) -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} - -- if (|`table*`| = |`tt*`|) + -- if (|`mem*`| = |`mt*`|) -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} - -- if (|`dt*`| = |`func*`|) + -- if (|`table*`| = |`tt*`|) -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} - -- if (|`data*`| = |`ok*`|) + -- if (|`dt*`| = |`func*`|) -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} - -- if (|`elem*`| = |`rt*`|) + -- if (|`data*`| = |`ok*`|) -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} + -- if (|`elem*`| = |`rt*`|) -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} + -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} -- if (|`export*`| = |`nm*`|) -- if (|`export*`| = |`xt_E*`|) - -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- if (C' = {TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) - -- if (x*{x <- `x*`} = $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))) - -- if (jt_I*{jt_I <- `jt_I*`} = $tagsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (gt_I*{gt_I <- `gt_I*`} = $globalsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (mt_I*{mt_I <- `mt_I*`} = $memsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (tt_I*{tt_I <- `tt_I*`} = $tablesxt(xt_I*{xt_I <- `xt_I*`})) - -- if (dt_I*{dt_I <- `dt_I*`} = $funcsxt(xt_I*{xt_I <- `xt_I*`})) + -- if (x*{x <- `x*`} = var_1) + -- if (jt_I*{jt_I <- `jt_I*`} = var_2) + -- if (gt_I*{gt_I <- `gt_I*`} = var_3) + -- if (mt_I*{mt_I <- `mt_I*`} = var_4) + -- if (tt_I*{tt_I <- `tt_I*`} = var_5) + -- if (dt_I*{dt_I <- `dt_I*`} = var_6) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`(var_0) + -- (wf_uN: `%%`(32, iter))*{iter <- var_1} + -- (wf_typeuse: `%`(iter))*{iter <- var_2} + -- (wf_globaltype: `%`(iter))*{iter <- var_3} + -- (wf_memtype: `%`(iter))*{iter <- var_4} + -- (wf_tabletype: `%`(iter))*{iter <- var_5} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7553,6 +9747,13 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`({TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) -- wf_nonfuncs: `%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) + -- fun_funcsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_6) + -- fun_tablesxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_5) + -- fun_memsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_4) + -- fun_globalsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_3) + -- fun_tagsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_2) + -- fun_funcidx_nonfuncs: `%%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}), var_1) + -- fun_clos_moduletype: `%%%`(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}), var_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed2 = @@ -7599,116 +9800,337 @@ def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_fmax : relaxed4 +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $R_idot : relaxed2 +def $R_fmax : relaxed4 + +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +def $R_idot : relaxed2 + +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_signed_: `%%%`(N, nat, int) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = (i : nat <:> int) + rule fun_signed__case_0{N : nat, i : nat}: + `%%%`(N, i, (i : nat <:> int)) -- if (i < (2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = ((i : nat <:> int) - ((2 ^ N) : nat <:> int)) + rule fun_signed__case_1{N : nat, i : nat}: + `%%%`(N, i, ((i : nat <:> int) - ((2 ^ N) : nat <:> int))) -- if (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) <= i) /\ (i < (2 ^ N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_signed_(N : N, int : int) : nat +relation fun_inv_signed_: `%%%`(N, int, nat) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = (i : int <:> nat) + rule fun_inv_signed__case_0{N : nat, i : int}: + `%%%`(N, i, (i : int <:> nat)) -- if (((0 : nat <:> int) <= i) /\ (i < ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = ((i + ((2 ^ N) : nat <:> int)) : int <:> nat) + rule fun_inv_signed__case_1{N : nat, i : int}: + `%%%`(N, i, ((i + ((2 ^ N) : nat <:> int)) : int <:> nat)) -- if ((- ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= i) /\ (i < (0 : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $sx(storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{consttype : consttype}((consttype : consttype <: storagetype)) = ?(?()) + def $sx(I32_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{packtype : packtype}((packtype : packtype <: storagetype)) = ?(?(S_sx)) + def $sx(F32_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(F64_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(V128_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I8_storagetype) = ?(?(S_sx)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I16_storagetype) = ?(?(S_sx)) def $sx{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) + def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(F32_lanetype) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + def $zero(F64_lanetype) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7737,12 +10159,12 @@ def $sat_s_(N : N, int : int) : int def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iabs_{N : nat, i_1 : uN}(N, i_1) = (if ($signed_(N, $proj_uN_0(i_1).0) >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + def $iabs_{N : nat, i_1 : uN, var_0 : int}(N, i_1) = (if (var_0 >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iclz_(N : N, iN : iN) : iN @@ -7754,61 +10176,81 @@ def $ictz_(N : N, iN : iN) : iN def $ipopcnt_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN +relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ M)))) + rule fun_iextend__case_0{N : nat, M : nat, i : uN}: + `%%%%%`(N, M, U_sx, i, `%`_iN(($proj_uN_0(i).0 \ (2 ^ M)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, ($proj_uN_0(i).0 \ (2 ^ M)))))) + rule fun_iextend__case_1{N : nat, M : nat, i : uN, var_1 : int, var_0 : nat}: + `%%%%%`(N, M, S_sx, i, `%`_iN(var_0)) + -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) + -- fun_inv_signed_: `%%%`(N, var_1, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) + rule fun_idiv__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?() - -- if ((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + rule fun_idiv__case_3{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}: + `%%%%%`(N, S_sx, i_1, i_2, ?()) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(N, $proj_uN_0(i_2).0) : int <:> rat)))))) + rule fun_idiv__case_4{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $truncz(((var_1 : int <:> rat) / (var_2 : int <:> rat))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) + rule fun_irem__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -- if ((j_1 = $signed_(N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) + rule fun_irem__case_3{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat))))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7819,7 +10261,9 @@ def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imin_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 <= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7830,25 +10274,29 @@ def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imax_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 >= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) + $signed_(N, $proj_uN_0(i_2).0)))))) + def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 + var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, $proj_uN_0(i_1).0) - $signed_(N, $proj_uN_0(i_2).0)))))) + def $isub_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 - var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7899,116 +10347,285 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) < $signed_(N, $proj_uN_0(i_2).0))))) + def $ilt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 < var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) > $signed_(N, $proj_uN_0(i_2).0))))) + def $igt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 > var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) <= $signed_(N, $proj_uN_0(i_2).0))))) + def $ile_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 <= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, $proj_uN_0(i_1).0) >= $signed_(N, $proj_uN_0(i_2).0))))) + def $ige_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 >= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsqrt_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fceil_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ffloor_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ftrunc_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fnearest_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fadd_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsub_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmul_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fdiv_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $feq_(N : N, fN : fN, fN : fN) : u32 @@ -8030,9 +10647,31 @@ def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -8051,801 +10690,4271 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) + def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c + def $cpacknum_{c : lit_}(I32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(I64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(F32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(F64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(V128_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), lit_) + -- if ($cunpack(storagetype) =/= ?()) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c + def $lunpacknum_{c : num_}(I32_lanetype, mk_lane__0_lane_(I32_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(I64_lanetype, mk_lane__0_lane_(I64_numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) + def $lunpacknum_{c : num_}(F32_lanetype, mk_lane__0_lane_(F32_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* +def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) + def $cunpacknum_{c : lit_}(I32_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) + def $cunpacknum_{c : lit_}(I64_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) + def $cunpacknum_{c : lit_}(F32_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) + def $cunpacknum_{c : lit_}(F64_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} + def $cunpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} + def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} + def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), ret_val) + -- if ($cunpack(storagetype) =/= ?()) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_0{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_1{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_2{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))]) -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_3{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_4{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_5{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} + rule fun_unop__case_6{M : nat, i : uN, var_0 : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} + rule fun_unop__case_7{M : nat, i : uN, var_0 : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_8{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#1)*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_9{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_10{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#3)*{iter_0#3 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_unop__case_11{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_unop__case_12{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#5)*{iter_0#5 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_13{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#6)*{iter_0#6 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_unop__case_14{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#7)*{iter_0#7 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_15{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_16{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#9)*{iter_0#9 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_17{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#10)*{iter_0#10 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_18{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#11)*{iter_0#11 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_19{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_20{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#13)*{iter_0#13 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_unop__case_21{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#14)*{iter_0#14 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)}) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $testop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_testop__0_testop_(Inn, EQZ_testop_Inn), mk_num__0_num_(Inn, i)) = $ieqz_($sizenn((Inn : addrtype <: numtype)), i) + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_unop_: `%%%%`(numtype, unop_, num_, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 +relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, EQ_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ieq_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) + rule fun_binop__case_0{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, NE_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ine_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) + rule fun_binop__case_1{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ilt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + rule fun_binop__case_2{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $igt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + rule fun_binop__case_3{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ile_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + rule fun_binop__case_4{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ige_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + rule fun_binop__case_5{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, EQ_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $feq_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_6{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#15)*{iter_0#15 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, NE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fne_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_7{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#16)*{iter_0#16 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $flt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_8{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#17)*{iter_0#17 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fgt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_9{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#18)*{iter_0#18 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fle_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_10{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fge_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + rule fun_binop__case_11{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) + rule fun_binop__case_12{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) + rule fun_binop__case_13{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} + rule fun_binop__case_14{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} + rule fun_binop__case_15{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) + rule fun_binop__case_16{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} + rule fun_binop__case_17{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} + rule fun_binop__case_18{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] - -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) + rule fun_binop__case_19{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] - -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) + rule fun_binop__case_20{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lanes_(shape : shape, vec_ : vec_) : lane_* + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_21{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $inv_lanes_(shape : shape, lane_*) : vec_ + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_22{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_23{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = half?{half <- `half?`} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_24{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#19)*{iter_0#19 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_25{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_26{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#21)*{iter_0#21 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_27{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#22)*{iter_0#22 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_28{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#23)*{iter_0#23 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_29{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_30{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#25)*{iter_0#25 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_31{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#26)*{iter_0#26 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_32{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#27)*{iter_0#27 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_33{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_34{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#29)*{iter_0#29 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_35{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#30)*{iter_0#30 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_36{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#31)*{iter_0#31 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_37{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#32)*{iter_0#32 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_binop_: `%%%%%`(numtype, binop_, num_, num__0, var_0) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $testop_{i : uN}(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i)) = $ieqz_($sizenn($numtype_addrtype(I32_Inn)), i) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $testop_{i : uN}(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i)) = $ieqz_($sizenn($numtype_addrtype(I64_Inn)), i) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, EQ_relop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ieq_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, EQ_relop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ieq_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, NE_relop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ine_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, NE_relop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ine_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ilt_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ilt_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $igt_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $igt_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ile_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ile_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ige_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ige_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, EQ_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $feq_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, EQ_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $feq_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, NE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fne_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, NE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fne_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, LT_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $flt_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, LT_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $flt_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, GT_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fgt_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GT_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fgt_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, LE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fle_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, LE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fle_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, GE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_cvtop__: `%%%%%`(numtype, numtype, cvtop__, num_, num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_0{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_1{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_2{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_3{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_4{i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_5{i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_6{i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_7{i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_8{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#33)*{iter_0#33 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_9{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_10{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#35)*{iter_0#35 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_11{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_12{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#37)*{iter_0#37 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_13{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#38)*{iter_0#38 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_14{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#39)*{iter_0#39 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_15{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#40)*{iter_0#40 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_16{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_17{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_18{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_19{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_20{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#41)*{iter_0#41 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_21{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_22{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#43)*{iter_0#43 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_23{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_24{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#45)*{iter_0#45 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_25{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_26{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#47)*{iter_0#47 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_27{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_28{i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))]) + -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F32_Fnn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_29{i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))]) + -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F32_Fnn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_30{i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))]) + -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F64_Fnn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_31{i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))]) + -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F64_Fnn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_32{f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I32_Inn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_33{f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I32_Inn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_34{f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I64_Inn))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_35{f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} + -- fun_cvtop__: `%%%%%`(numtype_1, numtype_2, cvtop__, num_, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $lanes_(shape : shape, vec_ : vec_) : lane_* + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $inv_lanes_(shape : shape, lane_*) : vec_ + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_zeroop: `%%%%`(shape, shape, vcvtop__, zero?) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`})), zero#3442?{zero#3442 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`})), zero#3444?{zero#3444 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`})), zero#3446?{zero#3446 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`})), zero#3448?{zero#3448 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`})), zero#3450?{zero#3450 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`})), zero#3452?{zero#3452 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`})), zero#3454?{zero#3454 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`})), zero#3456?{zero#3456 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`})), zero#3458?{zero#3458 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`})), zero#3460?{zero#3460 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`})), zero#3462?{zero#3462 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`})), zero#3464?{zero#3464 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`})), zero#3466?{zero#3466 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`})), zero#3468?{zero#3468 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`})), zero#3470?{zero#3470 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`})), zero#3472?{zero#3472 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_halfop: `%%%%`(shape, shape, vcvtop__, half?) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx)), half#3046?{half#3046 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx)), half#3048?{half#3048 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx)), half#3050?{half#3050 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx)), half#3052?{half#3052 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx)), half#3054?{half#3054 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx)), half#3056?{half#3056 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx)), half#3058?{half#3058 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx)), half#3060?{half#3060 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $half(half : half, nat : nat, nat : nat) : nat + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $half{i : nat, j : nat}(LOW_half, i, j) = i + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $half{i : nat, j : nat}(HIGH_half, i, j) = j + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $iswizzle_lane_(N : N, iN*, iN : iN) : iN + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#1*{c#1 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN, var_0 : int}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if (var_0 < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i).0, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#4)*{c#4 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#1*{c_1#1 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#3*{c#3 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#2)))*{c_1#2 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#6)*{c#6 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#3*{c_1#3 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#5*{c#5 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#8)*{c#8 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#10)*{c#10 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#7*{c_1#7 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#12*{c#12 <- `c*#2`})*{`c*#2` <- `c**`} + -- let{`c_1*` : lane_*} c_1#9*{c_1#9 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#11*{c#11 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49))*{iter_0#49 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#50))))*{iter_0#50 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#14*{c#14 <- `c*#4`})*{`c*#4` <- `c**`} + -- let{`c_1*` : lane_*} c_1#12*{c_1#12 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#13*{c#13 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51))*{iter_0#51 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#52))))*{iter_0#52 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#16)*{c#16 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#15*{c_1#15 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#1*{c_2#1 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#15*{c#15 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#18)*{c#18 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#3*{c_2#3 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#17*{c#17 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#20)*{c#20 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#19*{c_1#19 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#22)*{c#22 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#21*{c_1#21 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#7*{c_2#7 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#21*{c#21 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#24)*{c#24 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#9*{c_2#9 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#23*{c#23 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#26)*{c#26 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#25*{c_1#25 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#28)*{c#28 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#27*{c_1#27 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#13*{c_2#13 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#27*{c#27 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#15*{c_2#15 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#29*{c#29 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#32*{c#32 <- `c*#6`})*{`c*#6` <- `c**`} + -- let{`c_1*` : lane_*} c_1#31*{c_1#31 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#31*{c#31 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#53)*{iter_0#53 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#54)))*{iter_0#54 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#34*{c#34 <- `c*#8`})*{`c*#8` <- `c**`} + -- let{`c_1*` : lane_*} c_1#34*{c_1#34 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#33*{c#33 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#55)*{iter_0#55 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#56)))*{iter_0#56 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#36*{c#36 <- `c*#10`})*{`c*#10` <- `c**`} + -- let{`c_1*` : lane_*} c_1#37*{c_1#37 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#35*{c#35 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#57)*{iter_0#57 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#58)))*{iter_0#58 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#38*{c#38 <- `c*#12`})*{`c*#12` <- `c**`} + -- let{`c_1*` : lane_*} c_1#40*{c_1#40 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#37*{c#37 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#59)*{iter_0#59 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#60)))*{iter_0#60 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#40*{c#40 <- `c*#14`})*{`c*#14` <- `c**`} + -- let{`c_1*` : lane_*} c_1#43*{c_1#43 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#39*{c#39 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61))*{iter_0#61 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#62))))*{iter_0#62 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#42*{c#42 <- `c*#16`})*{`c*#16` <- `c**`} + -- let{`c_1*` : lane_*} c_1#46*{c_1#46 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#41*{c#41 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63))*{iter_0#63 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#64))))*{iter_0#64 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#18`})*{`c*#18` <- `c**`} + -- let{`c_1*` : lane_*} c_1#49*{c_1#49 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#1*{c_3#1 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#43*{c#43 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#65)*{iter_0#65 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#66)))*{iter_0#66 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#20`})*{`c*#20` <- `c**`} + -- let{`c_1*` : lane_*} c_1#52*{c_1#52 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#4*{c_3#4 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#45*{c#45 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#67)*{iter_0#67 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#68)))*{iter_0#68 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#22`})*{`c*#22` <- `c**`} + -- let{`c_1*` : lane_*} c_1#55*{c_1#55 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#7*{c_3#7 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#47*{c#47 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#69)*{iter_0#69 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#70)))*{iter_0#70 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#24`})*{`c*#24` <- `c**`} + -- let{`c_1*` : lane_*} c_1#58*{c_1#58 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#10*{c_3#10 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#49*{c#49 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#71)*{iter_0#71 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#72)))*{iter_0#72 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#26`})*{`c*#26` <- `c**`} + -- let{`c_1*` : lane_*} c_1#61*{c_1#61 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#13*{c_3#13 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#51*{c#51 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#73))*{iter_0#73 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#74))))*{iter_0#74 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#28`})*{`c*#28` <- `c**`} + -- let{`c_1*` : lane_*} c_1#64*{c_1#64 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#16*{c_3#16 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#53*{c#53 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#75))*{iter_0#75 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#76))))*{iter_0#76 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#56)*{c#56 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#67*{c_1#67 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#55*{c#55 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- `c_1*`, c_2#55 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#58)*{c#58 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#70*{c_1#70 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#57*{c#57 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- `c_1*`, c_2#58 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#60)*{c#60 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#73*{c_1#73 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#59*{c#59 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- `c_1*`, c_2#61 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#62)*{c#62 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#76*{c_1#76 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#61*{c#61 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- `c_1*`, c_2#64 <- `c_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#64)*{c#64 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#79*{c_1#79 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#63*{c#63 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- `c_1*`, c_2#67 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#66)*{c#66 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#82*{c_1#82 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#65*{c#65 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- `c_1*`, c_2#70 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#68)*{c#68 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#85*{c_1#85 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- `c_1*`, c_2#73 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#70)*{c#70 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#88*{c_1#88 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#69*{c#69 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- `c_1*`, c_2#76 <- `c_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#72).0)))*{c#72 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#91*{c_1#91 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#71*{c#71 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} + -- if ($isize(Inn) = $fsize(F32_Fnn)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- `c_1*`, c_2#79 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#74).0)))*{c#74 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#94*{c_1#94 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} + -- if ($isize(Inn) = $fsize(F64_Fnn)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- `c_1*`, c_2#82 <- `c_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#76)*{c#76 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#97*{c_1#97 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#75*{c#75 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#78)*{c#78 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#99*{c_1#99 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#77*{c#77 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#80)*{c#80 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#82)*{c#82 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#103*{c_1#103 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#81*{c#81 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#84)*{c#84 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#105*{c_1#105 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#83*{c#83 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#86)*{c#86 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#88)*{c#88 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#109*{c_1#109 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#87*{c#87 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#111*{c_1#111 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#89*{c#89 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_ivbitmaskop_: `%%%`(shape, vec_, u32) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_0{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#114) =/= ?()))*{c_1#114 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- `c_1*`} + -- (if ($proj_lane__2(c_1#115) =/= ?()))*{c_1#115 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#117) =/= ?()))*{c_1#117 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- `c_1*`} + -- (if ($proj_lane__2(c_1#118) =/= ?()))*{c_1#118 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#120) =/= ?()))*{c_1#120 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- `c_1*`} + -- (if ($proj_lane__2(c_1#121) =/= ?()))*{c_1#121 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#123) =/= ?()))*{c_1#123 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- `c_1*`} + -- (if ($proj_lane__2(c_1#124) =/= ?()))*{c_1#124 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#92)*{c#92 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#94)*{c#94 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#127*{c_1#127 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#85*{c_2#85 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#93*{c#93 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#96)*{c#96 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#129*{c_1#129 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#87*{c_2#87 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#95*{c#95 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#98)*{c#98 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_ivshufflop_: `%%%%%`(shape, laneidx*, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139040*{i#139040 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#100*{c#100 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#133*{c_1#133 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#91*{c_2#91 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#99*{c#99 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139043).0]*{i#139043 <- `i*`} + -- (if ($proj_uN_0(i#139043).0 < |c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}|))*{i#139043 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139047*{i#139047 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#102*{c#102 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#135*{c_1#135 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#93*{c_2#93 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#101*{c#101 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139050).0]*{i#139050 <- `i*`} + -- (if ($proj_uN_0(i#139050).0 < |c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}|))*{i#139050 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139054*{i#139054 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#104*{c#104 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#103*{c#103 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139057).0]*{i#139057 <- `i*`} + -- (if ($proj_uN_0(i#139057).0 < |c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}|))*{i#139057 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139061*{i#139061 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#106*{c#106 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#139*{c_1#139 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#97*{c_2#97 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#105*{c#105 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139064).0]*{i#139064 <- `i*`} + -- (if ($proj_uN_0(i#139064).0 < |c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}|))*{i#139064 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvunop_(vectype : vectype, vvunop : vvunop, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvunop_{Vnn : vectype, v : uN}(Vnn, NOT_vvunop, v) = [$inot_($vsizenn(Vnn), v)] + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, AND_vvbinop, v_1, v_2) = [$iand_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, ANDNOT_vvbinop, v_1, v_2) = [$iandnot_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, OR_vvbinop, v_1, v_2) = [$ior_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, XOR_vvbinop, v_1, v_2) = [$ixor_($vsizenn(Vnn), v_1, v_2)] + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vunop_: `%%%%`(shape, vunop_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_0{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_1{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_2{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_3{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_4{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_5{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_6{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_7{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_8{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_9{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_10{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_11{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_12{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_13{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_14{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_15{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_16{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_17{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_18{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_19{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_20{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_21{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_22{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_23{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_24{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_25{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vbinop_: `%%%%%`(shape, vbinop_, vec_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_8{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_9{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_10{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_11{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_24{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_25{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_26{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_27{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_36{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_37{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_38{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_39{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_40{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_41{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_42{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_43{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_44{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_45{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_46{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_47{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_48{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_49{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_50{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_51{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_52{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_53{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_54{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_55{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_56{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_57{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_58{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_59{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vternop_: `%%%%%%`(shape, vternop_, vec_, vec_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_0{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_1{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_2{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_3{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_4{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_5{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_6{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_7{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vrelop_: `%%%%%`(shape, vrelop_, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_8{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_9{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_10{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_11{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_24{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_25{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_26{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_27{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $half(half : half, nat : nat, nat : nat) : nat +relation fun_lcvtop__: `%%%%%`(shape, shape, vcvtop__, lane_, lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(LOW_half, i, j) = i + rule fun_lcvtop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(HIGH_half, i, j) = j + rule fun_lcvtop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#108))?{c#108 <- `c?`})) + -- let{`c?` : iN?} c#107?{c#107 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#110))?{c#110 <- `c?`})) + -- let{`c?` : iN?} c#109?{c#109 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#112))?{c#112 <- `c?`})) + -- let{`c?` : iN?} c#111?{c#111 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#114))?{c#114 <- `c?`})) + -- let{`c?` : iN?} c#113?{c#113 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#116))?{c#116 <- `c?`})) + -- let{`c?` : iN?} c#115?{c#115 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#118))?{c#118 <- `c?`})) + -- let{`c?` : iN?} c#117?{c#117 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#120))?{c#120 <- `c?`})) + -- let{`c?` : iN?} c#119?{c#119 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#122))?{c#122 <- `c?`})) + -- let{`c?` : iN?} c#121?{c#121 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#124))?{c#124 <- `c?`})) + -- let{`c?` : iN?} c#123?{c#123 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#126))?{c#126 <- `c?`})) + -- let{`c?` : iN?} c#125?{c#125 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#128))?{c#128 <- `c?`})) + -- let{`c?` : iN?} c#127?{c#127 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#130))?{c#130 <- `c?`})) + -- let{`c?` : iN?} c#129?{c#129 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#132))?{c#132 <- `c?`})) + -- let{`c?` : iN?} c#131?{c#131 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#134))?{c#134 <- `c?`})) + -- let{`c?` : iN?} c#133?{c#133 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#136))?{c#136 <- `c?`})) + -- let{`c?` : iN?} c#135?{c#135 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#138))?{c#138 <- `c?`})) + -- let{`c?` : iN?} c#137?{c#137 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#140))?{c#140 <- `c?`})) + -- let{`c?` : iN?} c#139?{c#139 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))?{c#142 <- `c?`})) + -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#144))?{c#144 <- `c?`})) + -- let{`c?` : iN?} c#143?{c#143 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`})) + -- let{`c?` : iN?} c#145?{c#145 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#148))?{c#148 <- `c?`})) + -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#150))?{c#150 <- `c?`})) + -- let{`c?` : iN?} c#149?{c#149 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#152))?{c#152 <- `c?`})) + -- let{`c?` : iN?} c#151?{c#151 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))?{c#154 <- `c?`})) + -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#156))?{c#156 <- `c?`})) + -- let{`c?` : iN?} c#155?{c#155 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#158))?{c#158 <- `c?`})) + -- let{`c?` : iN?} c#157?{c#157 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#160))?{c#160 <- `c?`})) + -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#162))?{c#162 <- `c?`})) + -- let{`c?` : iN?} c#161?{c#161 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`})) + -- let{`c?` : iN?} c#163?{c#163 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#166))?{c#166 <- `c?`})) + -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#168))?{c#168 <- `c?`})) + -- let{`c?` : iN?} c#167?{c#167 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#170))?{c#170 <- `c?`})) + -- let{`c?` : iN?} c#169?{c#169 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#172))*{c#172 <- `c*`}) + -- let{`c*` : fN*} c#171*{c#171 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#174))*{c#174 <- `c*`}) + -- let{`c*` : fN*} c#173*{c#173 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#176))*{c#176 <- `c*`}) + -- let{`c*` : fN*} c#175*{c#175 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#178))*{c#178 <- `c*`}) + -- let{`c*` : fN*} c#177*{c#177 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#180))*{c#180 <- `c*`}) + -- let{`c*` : fN*} c#179*{c#179 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#182))*{c#182 <- `c*`}) + -- let{`c*` : fN*} c#181*{c#181 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#184))*{c#184 <- `c*`}) + -- let{`c*` : fN*} c#183*{c#183 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#186))*{c#186 <- `c*`}) + -- let{`c*` : fN*} c#185*{c#185 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#188))*{c#188 <- `c*`}) + -- let{`c*` : fN*} c#187*{c#187 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#190))*{c#190 <- `c*`}) + -- let{`c*` : fN*} c#189*{c#189 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#192))*{c#192 <- `c*`}) + -- let{`c*` : fN*} c#191*{c#191 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#194))*{c#194 <- `c*`}) + -- let{`c*` : fN*} c#193*{c#193 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#196))*{c#196 <- `c*`}) + -- let{`c*` : fN*} c#195*{c#195 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#198))*{c#198 <- `c*`}) + -- let{`c*` : fN*} c#197*{c#197 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#200))*{c#200 <- `c*`}) + -- let{`c*` : fN*} c#199*{c#199 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#202))*{c#202 <- `c*`}) + -- let{`c*` : fN*} c#201*{c#201 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $iswizzle_lane_(N : N, iN*, iN : iN) : iN +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*, var_0 : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = var_0) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} + -- fun_lcvtop__: `%%%%%`(shape_1, shape_2, vcvtop__, lane_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN +relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_0{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M_0)), vcvtop, v_1, v) + -- if ((var_0 = ?()) /\ (var_1 = ?())) + -- let{`c_1*` : lane_*} c_1#141*{c_1#141 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#203*{c#203 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if (M = M_0) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142, var_2))*{var_2 <- `var_2*`, c_1#142 <- `c_1*`} + -- if (|`var_2*`| = |`c_1*`|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_1{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half, `var_1*` : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(half)) + -- let{`c_1*` : lane_*} c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] + -- let{`c**` : lane_**} c#205*{c#205 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144, var_1))*{var_1 <- `var_1*`, c_1#144 <- `c_1*`} + -- if (|`var_1*`| = |`c_1*`|) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if ($signed_(N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(ZERO_zero)) + -- let{`c_1*` : lane_*} c_1#145*{c_1#145 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) + -- let{`c**` : lane_**} c#207*{c#207 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [$zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146, var_1))*{var_1 <- `var_1*`, c_1#146 <- `c_1*`} + -- if (|`var_1*`| = |`c_1*`|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* +relation fun_vshiftop_: `%%%%%`(ishape, vshiftop_, vec_, u32, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_0{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_1{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_2{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_3{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_4{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_5{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_6{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vshiftop__case_7{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* +relation fun_vbitmaskop_: `%%%`(ishape, vec_, u32) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_0{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_1{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`} + rule fun_vbitmaskop__case_2{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_3{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vswizzlop_: `%%%%%`(bshape, vswizzlop_, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vswizzlop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2)) + -- if (M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vswizzlop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2)) + -- if (M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vshufflop_: `%%%%%`(bshape, laneidx*, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139530*{i#139530 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vnarrowop__: `%%%%%%`(shape, shape, sx, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#147*{c_1#147 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#99*{c_2#99 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#1*{c'_1#1 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#148)))*{c_1#148 <- `c_1*`} + -- (if ($proj_lane__2(c_1#148) =/= ?()))*{c_1#148 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#1*{c'_2#1 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#100)))*{c_2#100 <- `c_2*`} + -- (if ($proj_lane__2(c_2#100) =/= ?()))*{c_2#100 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#2)*{c'_1#2 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#2)*{c'_2#2 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#3)))*{c'_1#3 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#3)))*{c'_2#3 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#149*{c_1#149 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#101*{c_2#101 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#4*{c'_1#4 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#150)))*{c_1#150 <- `c_1*`} + -- (if ($proj_lane__2(c_1#150) =/= ?()))*{c_1#150 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#4*{c'_2#4 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#102)))*{c_2#102 <- `c_2*`} + -- (if ($proj_lane__2(c_2#102) =/= ?()))*{c_2#102 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#5)*{c'_1#5 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#5)*{c'_2#5 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#6)))*{c'_1#6 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#6)))*{c'_2#6 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#151*{c_1#151 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#103*{c_2#103 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#7*{c'_1#7 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#152)))*{c_1#152 <- `c_1*`} + -- (if ($proj_lane__2(c_1#152) =/= ?()))*{c_1#152 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#7*{c'_2#7 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#104)))*{c_2#104 <- `c_2*`} + -- (if ($proj_lane__2(c_2#104) =/= ?()))*{c_2#104 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#8)*{c'_1#8 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#8)*{c'_2#8 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#9)))*{c'_1#9 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#9)))*{c'_2#9 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#153*{c_1#153 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#105*{c_2#105 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#10*{c'_1#10 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#154)))*{c_1#154 <- `c_1*`} + -- (if ($proj_lane__2(c_1#154) =/= ?()))*{c_1#154 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#10*{c'_2#10 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#106)))*{c_2#106 <- `c_2*`} + -- (if ($proj_lane__2(c_2#106) =/= ?()))*{c_2#106 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#11)*{c'_1#11 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#11)*{c'_2#11 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#12)))*{c'_1#12 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#12)))*{c'_2#12 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#155*{c_1#155 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#13*{c'_1#13 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#156)))*{c_1#156 <- `c_1*`} + -- (if ($proj_lane__2(c_1#156) =/= ?()))*{c_1#156 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#13*{c'_2#13 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#108)))*{c_2#108 <- `c_2*`} + -- (if ($proj_lane__2(c_2#108) =/= ?()))*{c_2#108 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#14)*{c'_1#14 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#14)*{c'_2#14 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#15)))*{c'_1#15 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#15)))*{c'_2#15 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#157*{c_1#157 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#109*{c_2#109 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#16*{c'_1#16 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#158)))*{c_1#158 <- `c_1*`} + -- (if ($proj_lane__2(c_1#158) =/= ?()))*{c_1#158 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#16*{c'_2#16 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#110)))*{c_2#110 <- `c_2*`} + -- (if ($proj_lane__2(c_2#110) =/= ?()))*{c_2#110 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#17)*{c'_1#17 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#17)*{c'_2#17 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#18)))*{c'_1#18 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#18)))*{c'_2#18 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#159*{c_1#159 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#111*{c_2#111 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#19*{c'_1#19 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#160)))*{c_1#160 <- `c_1*`} + -- (if ($proj_lane__2(c_1#160) =/= ?()))*{c_1#160 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#19*{c'_2#19 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#112)))*{c_2#112 <- `c_2*`} + -- (if ($proj_lane__2(c_2#112) =/= ?()))*{c_2#112 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#20)*{c'_1#20 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#20)*{c'_2#20 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#21)))*{c'_1#21 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#21)))*{c'_2#21 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#113*{c_2#113 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#22*{c'_1#22 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#162)))*{c_1#162 <- `c_1*`} + -- (if ($proj_lane__2(c_1#162) =/= ?()))*{c_1#162 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#22*{c'_2#22 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#114)))*{c_2#114 <- `c_2*`} + -- (if ($proj_lane__2(c_2#114) =/= ?()))*{c_2#114 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#23)*{c'_1#23 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#23)*{c'_2#23 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#24)))*{c'_1#24 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#24)))*{c'_2#24 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#163*{c_1#163 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#115*{c_2#115 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#25*{c'_1#25 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#164)))*{c_1#164 <- `c_1*`} + -- (if ($proj_lane__2(c_1#164) =/= ?()))*{c_1#164 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#25*{c'_2#25 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#116)))*{c_2#116 <- `c_2*`} + -- (if ($proj_lane__2(c_2#116) =/= ?()))*{c_2#116 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#26)*{c'_1#26 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#26)*{c'_2#26 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#27)))*{c'_1#27 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#27)))*{c'_2#27 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#165*{c_1#165 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#117*{c_2#117 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#28*{c'_1#28 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#166)))*{c_1#166 <- `c_1*`} + -- (if ($proj_lane__2(c_1#166) =/= ?()))*{c_1#166 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#28*{c'_2#28 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#118)))*{c_2#118 <- `c_2*`} + -- (if ($proj_lane__2(c_2#118) =/= ?()))*{c_2#118 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#29)*{c'_1#29 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#29)*{c'_2#29 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#30)))*{c'_1#30 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#30)))*{c'_2#30 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#167*{c_1#167 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#119*{c_2#119 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#31*{c'_1#31 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#168)))*{c_1#168 <- `c_1*`} + -- (if ($proj_lane__2(c_1#168) =/= ?()))*{c_1#168 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#31*{c'_2#31 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- `c_2*`} + -- (if ($proj_lane__2(c_2#120) =/= ?()))*{c_2#120 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#32)*{c'_1#32 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#32)*{c'_2#32 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#33)))*{c'_1#33 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#33)))*{c'_2#33 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#169*{c_1#169 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#121*{c_2#121 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#34*{c'_1#34 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#170)))*{c_1#170 <- `c_1*`} + -- (if ($proj_lane__2(c_1#170) =/= ?()))*{c_1#170 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#34*{c'_2#34 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#122)))*{c_2#122 <- `c_2*`} + -- (if ($proj_lane__2(c_2#122) =/= ?()))*{c_2#122 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#35)*{c'_1#35 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#35)*{c'_2#35 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#36)))*{c'_1#36 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#36)))*{c'_2#36 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#171*{c_1#171 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#123*{c_2#123 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#37*{c'_1#37 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#172)))*{c_1#172 <- `c_1*`} + -- (if ($proj_lane__2(c_1#172) =/= ?()))*{c_1#172 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#37*{c'_2#37 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#124)))*{c_2#124 <- `c_2*`} + -- (if ($proj_lane__2(c_2#124) =/= ?()))*{c_2#124 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#38)*{c'_1#38 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#38)*{c'_2#38 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#39)))*{c'_1#39 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#39)))*{c'_2#39 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#125*{c_2#125 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#40*{c'_1#40 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#174)))*{c_1#174 <- `c_1*`} + -- (if ($proj_lane__2(c_1#174) =/= ?()))*{c_1#174 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#40*{c'_2#40 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- `c_2*`} + -- (if ($proj_lane__2(c_2#126) =/= ?()))*{c_2#126 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#41)*{c'_1#41 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#41)*{c'_2#41 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#42)))*{c'_1#42 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#42)))*{c'_2#42 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#175*{c_1#175 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#127*{c_2#127 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#43*{c'_1#43 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#176)))*{c_1#176 <- `c_1*`} + -- (if ($proj_lane__2(c_1#176) =/= ?()))*{c_1#176 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#43*{c'_2#43 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#128)))*{c_2#128 <- `c_2*`} + -- (if ($proj_lane__2(c_2#128) =/= ?()))*{c_2#128 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#44)*{c'_1#44 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#44)*{c'_2#44 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#45)))*{c'_1#45 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#45)))*{c'_2#45 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_vnarrowop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#177*{c_1#177 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#129*{c_2#129 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#46*{c'_1#46 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#178)))*{c_1#178 <- `c_1*`} + -- (if ($proj_lane__2(c_1#178) =/= ?()))*{c_1#178 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#46*{c'_2#46 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#130)))*{c_2#130 <- `c_2*`} + -- (if ($proj_lane__2(c_2#130) =/= ?()))*{c_2#130 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#47)*{c'_1#47 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#47)*{c'_2#47 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#48)))*{c'_1#48 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#48)))*{c'_2#48 <- `c'_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* +def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} + def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139675*{i#139675 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139676).0*{i#139676 <- `i*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* +def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#210)*{c#210 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#49*{c'_1#49 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`} + -- let{`c*` : iN*} c#209*{c#209 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#212)*{c#212 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#181*{c_1#181 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#51*{c'_1#51 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- `c_1*`} + -- let{`c*` : iN*} c#211*{c#211 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#214)*{c#214 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#183*{c_1#183 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- `c_1*`} + -- let{`c*` : iN*} c#213*{c#213 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#216)*{c#216 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#55*{c'_1#55 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`} + -- let{`c*` : iN*} c#215*{c#215 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#218)*{c#218 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#187*{c_1#187 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#57*{c'_1#57 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- `c_1*`} + -- let{`c*` : iN*} c#217*{c#217 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#220)*{c#220 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#189*{c_1#189 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- `c_1*`} + -- let{`c*` : iN*} c#219*{c#219 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#222)*{c#222 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#61*{c'_1#61 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`} + -- let{`c*` : iN*} c#221*{c#221 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#224)*{c#224 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#193*{c_1#193 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#63*{c'_1#63 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- `c_1*`} + -- let{`c*` : iN*} c#223*{c#223 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#226)*{c#226 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#195*{c_1#195 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- `c_1*`} + -- let{`c*` : iN*} c#225*{c#225 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#228)*{c#228 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#67*{c'_1#67 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`} + -- let{`c*` : iN*} c#227*{c#227 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#230)*{c#230 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#199*{c_1#199 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#69*{c'_1#69 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- `c_1*`} + -- let{`c*` : iN*} c#229*{c#229 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#232)*{c#232 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#201*{c_1#201 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- `c_1*`} + -- let{`c*` : iN*} c#231*{c#231 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#234)*{c#234 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#73*{c'_1#73 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`} + -- let{`c*` : iN*} c#233*{c#233 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#236)*{c#236 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#205*{c_1#205 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#75*{c'_1#75 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- `c_1*`} + -- let{`c*` : iN*} c#235*{c#235 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#238)*{c#238 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#207*{c_1#207 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- `c_1*`} + -- let{`c*` : iN*} c#237*{c#237 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#240)*{c#240 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#79*{c'_1#79 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`} + -- let{`c*` : iN*} c#239*{c#239 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vextunop__: `%%%%%`(ishape, ishape, vextunop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} + rule fun_vextunop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_vextunop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_vextunop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c).0)))*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($proj_uN_0($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))).0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c).0)))))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))).0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_vextunop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vextunop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vextunop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))).0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))).0)))*{c_1 <- `c_1*`} - -- wf_bit: `%`(`%`_bit(0)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{Jnn : Jnn, M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_vextunop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ +def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{Jnn : Jnn, M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c*{c <- `c*`} = c_1*{c_1 <- `c_1*`} ++ c_2*{c_2 <- `c_2*`}[$proj_uN_0(i).0]*{i <- `i*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#1*{i_1#1 <- `i_1*`}, i_2#1*{i_2#1 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvunop_(vectype : vectype, vvunop : vvunop, vec_ : vec_) : vec_* +def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvunop_{Vnn : vectype, v : uN}(Vnn, NOT_vvunop, v) = [$inot_($vsizenn(Vnn), v)] + def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#3*{i_1#3 <- `i_1*`}, i_2#3*{i_2#3 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* +def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, AND_vvbinop, v_1, v_2) = [$iand_($vsizenn(Vnn), v_1, v_2)] + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#242)*{c#242 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#211*{c_1#211 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#81*{c'_1#81 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#49*{c'_2#49 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`} + -- let{`c*` : iN*} c#241*{c#241 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, ANDNOT_vvbinop, v_1, v_2) = [$iandnot_($vsizenn(Vnn), v_1, v_2)] + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#244)*{c#244 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#213*{c_1#213 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#133*{c_2#133 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#51*{c'_2#51 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- `c_2*`} + -- let{`c*` : iN*} c#243*{c#243 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, OR_vvbinop, v_1, v_2) = [$ior_($vsizenn(Vnn), v_1, v_2)] + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#246)*{c#246 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#135*{c_2#135 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#85*{c'_1#85 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- `c_2*`} + -- let{`c*` : iN*} c#245*{c#245 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, XOR_vvbinop, v_1, v_2) = [$ixor_($vsizenn(Vnn), v_1, v_2)] - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#248)*{c#248 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#217*{c_1#217 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#87*{c'_1#87 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#55*{c'_2#55 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`} + -- let{`c*` : iN*} c#247*{c#247 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] - -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#250)*{c#250 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#219*{c_1#219 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#139*{c_2#139 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#57*{c'_2#57 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- `c_2*`} + -- let{`c*` : iN*} c#249*{c#249 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#252)*{c#252 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#141*{c_2#141 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#91*{c'_1#91 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- `c_2*`} + -- let{`c*` : iN*} c#251*{c#251 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#254)*{c#254 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#223*{c_1#223 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#93*{c'_1#93 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#61*{c'_2#61 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`} + -- let{`c*` : iN*} c#253*{c#253 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#256)*{c#256 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#225*{c_1#225 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#145*{c_2#145 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#63*{c'_2#63 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- `c_2*`} + -- let{`c*` : iN*} c#255*{c#255 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#258)*{c#258 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#147*{c_2#147 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#97*{c'_1#97 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- `c_2*`} + -- let{`c*` : iN*} c#257*{c#257 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#260)*{c#260 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#229*{c_1#229 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#99*{c'_1#99 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#67*{c'_2#67 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`} + -- let{`c*` : iN*} c#259*{c#259 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#262)*{c#262 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#231*{c_1#231 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#151*{c_2#151 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#69*{c'_2#69 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- `c_2*`} + -- let{`c*` : iN*} c#261*{c#261 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#264)*{c#264 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#153*{c_2#153 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#103*{c'_1#103 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- `c_2*`} + -- let{`c*` : iN*} c#263*{c#263 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#266)*{c#266 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#235*{c_1#235 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#105*{c'_1#105 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#73*{c'_2#73 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`} + -- let{`c*` : iN*} c#265*{c#265 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#268)*{c#268 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#237*{c_1#237 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#157*{c_2#157 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#75*{c'_2#75 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- `c_2*`} + -- let{`c*` : iN*} c#267*{c#267 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#270)*{c#270 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#159*{c_2#159 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#109*{c'_1#109 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- `c_2*`} + -- let{`c*` : iN*} c#269*{c#269 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#272)*{c#272 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#241*{c_1#241 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#111*{c'_1#111 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#79*{c'_2#79 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`} + -- let{`c*` : iN*} c#271*{c#271 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivmul_(N : N, iN*, iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1#5*{i_1#5 <- `i_1*`}, i_2#5*{i_2#5 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_vextbinop__: `%%%%%%`(ishape, ishape, vextbinop__, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_16{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_17{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_18{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_19{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_20{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_21{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_22{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_23{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_24{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_25{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_26{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_27{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_28{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_29{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_30{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_31{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_32{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_33{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_34{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_35{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_36{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] - -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) + rule fun_vextbinop___case_37{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] - -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) + rule fun_vextbinop___case_38{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} + rule fun_vextbinop___case_39{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} + rule fun_vextbinop___case_40{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + rule fun_vextbinop___case_41{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + rule fun_vextbinop___case_42{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v - -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + rule fun_vextbinop___case_43{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + rule fun_vextbinop___case_44{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_45{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_46{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_vextbinop___case_47{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ +relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vextternop___case_0{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vextternop___case_1{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + rule fun_vextternop___case_2{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), sx, v_1, v_2) = v - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c'_1)*{c'_1 <- `c'_1*`} ++ mk_lane__2_lane_(Jnn_2, c'_2)*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_1)))*{c'_1 <- `c'_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_2)))*{c'_2 <- `c'_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_3{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivadd_pairwise_(N : N, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $proj_uN_0(i).0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} + rule fun_vextternop___case_4{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) + rule fun_vextternop___case_5{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + rule fun_vextternop___case_6{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} + rule fun_vextternop___case_7{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_sat_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} + rule fun_vextternop___case_8{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) + rule fun_vextternop___case_9{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_10{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivmul_(N : N, iN*, iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} + rule fun_vextternop___case_11{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_12{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_13{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_14{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c - -- if ($jsizenn(Jnn) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) + rule fun_vextternop___case_15{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M)) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = | CONST(numtype : numtype, num_) +def $val_num(num) : val + def $val_num{x0 : numtype, x1 : num_}(CONST_num(x0, x1)) = CONST_val(x0, x1) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_num: `%`(num) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -8857,6 +14966,9 @@ relation wf_num: `%`(num) syntax vec = | VCONST(vectype : vectype, vec_) +def $val_vec(vec) : val + def $val_vec{x0 : vectype, x1 : vec_}(VCONST_vec(x0, x1)) = VCONST_val(x0, x1) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_vec: `%`(vec) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -8894,6 +15006,9 @@ syntax funccode = | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) | `...` +def $funccode_func(func) : funccode + def $funccode_func{x0 : typeidx, x1 : local*, x2 : expr}(FUNC_func(x0, x1, x2)) = FUNC_funccode(x0, x1, x2) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_funccode: `%`(funccode) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9034,6 +15149,31 @@ syntax fieldval = | `REF.EXTERN`(ref : ref) | PACK(packtype : packtype, iN) +def $fieldval_packval(packval) : fieldval + def $fieldval_packval{x0 : packtype, x1 : iN}(PACK_packval(x0, x1)) = PACK_fieldval(x0, x1) + +def $fieldval_ref(ref) : fieldval + def $fieldval_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_fieldval(x0) + def $fieldval_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_fieldval + def $fieldval_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_fieldval(x0) + +def $fieldval_val(val) : fieldval + def $fieldval_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_fieldval(x0, x1) + def $fieldval_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_fieldval(x0, x1) + def $fieldval_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_fieldval(x0) + def $fieldval_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_fieldval + def $fieldval_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) + def $fieldval_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) + def $fieldval_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_fieldval(x0) + def $fieldval_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_fieldval(x0) + def $fieldval_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_fieldval(x0) + def $fieldval_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_fieldval(x0) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_fieldval: `%`(fieldval) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9145,131 +15285,340 @@ syntax store = ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_store: `%`(store) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule store_case_{var_0 : taginst*, var_1 : globalinst*, var_2 : meminst*, var_3 : tableinst*, var_4 : funcinst*, var_5 : datainst*, var_6 : eleminst*, var_7 : structinst*, var_8 : arrayinst*, var_9 : exninst*}: - `%`({TAGS var_0, GLOBALS var_1, MEMS var_2, TABLES var_3, FUNCS var_4, DATAS var_5, ELEMS var_6, STRUCTS var_7, ARRAYS var_8, EXNS var_9}) - -- (wf_taginst: `%`(var_0))*{var_0 <- var_0} - -- (wf_globalinst: `%`(var_1))*{var_1 <- var_1} - -- (wf_meminst: `%`(var_2))*{var_2 <- var_2} - -- (wf_tableinst: `%`(var_3))*{var_3 <- var_3} - -- (wf_funcinst: `%`(var_4))*{var_4 <- var_4} - -- (wf_datainst: `%`(var_5))*{var_5 <- var_5} - -- (wf_eleminst: `%`(var_6))*{var_6 <- var_6} - -- (wf_structinst: `%`(var_7))*{var_7 <- var_7} - -- (wf_arrayinst: `%`(var_8))*{var_8 <- var_8} - -- (wf_exninst: `%`(var_9))*{var_9 <- var_9} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax state = - | `%;%`(store : store, frame : frame) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_state: `%`(state) + rule store_case_{var_0 : taginst*, var_1 : globalinst*, var_2 : meminst*, var_3 : tableinst*, var_4 : funcinst*, var_5 : datainst*, var_6 : eleminst*, var_7 : structinst*, var_8 : arrayinst*, var_9 : exninst*}: + `%`({TAGS var_0, GLOBALS var_1, MEMS var_2, TABLES var_3, FUNCS var_4, DATAS var_5, ELEMS var_6, STRUCTS var_7, ARRAYS var_8, EXNS var_9}) + -- (wf_taginst: `%`(var_0))*{var_0 <- var_0} + -- (wf_globalinst: `%`(var_1))*{var_1 <- var_1} + -- (wf_meminst: `%`(var_2))*{var_2 <- var_2} + -- (wf_tableinst: `%`(var_3))*{var_3 <- var_3} + -- (wf_funcinst: `%`(var_4))*{var_4 <- var_4} + -- (wf_datainst: `%`(var_5))*{var_5 <- var_5} + -- (wf_eleminst: `%`(var_6))*{var_6 <- var_6} + -- (wf_structinst: `%`(var_7))*{var_7 <- var_7} + -- (wf_arrayinst: `%`(var_8))*{var_8 <- var_8} + -- (wf_exninst: `%`(var_9))*{var_9 <- var_9} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax state = + | `%;%`(store : store, frame : frame) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_state: `%`(state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule state_case_0{store : store, frame : frame}: + `%`(`%;%`_state(store, frame)) + -- wf_store: `%`(store) + -- wf_frame: `%`(frame) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax config = + | `%;%`(state : state, `instr*` : instr*) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_config: `%`(config) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule config_case_0{state : state, `instr*` : instr*}: + `%`(`%;%`_config(state, `instr*`)) + -- wf_state: `%`(state) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $Ki : nat + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $Ki = 1024 + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $packfield_(storagetype : storagetype, val : val) : fieldval? + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(BOT_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{`null?` : null?, heaptype : heaptype, val : val}(REF_storagetype(`null?`, heaptype), val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(V128_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(F64_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(F32_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(I64_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(I32_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() + -- otherwise + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- if ($packfield_(storagetype, val) =/= ?()) + -- wf_fieldval: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{`null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule state_case_0{store : store, frame : frame}: - `%`(`%;%`_state(store, frame)) - -- wf_store: `%`(store) - -- wf_frame: `%`(frame) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax config = - | `%;%`(state : state, `instr*` : instr*) - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_config: `%`(config) + def $unpackfield_{vectype : vectype, var_1 : vec_}(BOT_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule config_case_0{state : state, `instr*` : instr*}: - `%`(`%;%`_config(state, `instr*`)) - -- wf_state: `%`(state) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $Ki : nat + def $unpackfield_{vectype : vectype, var_1 : vec_, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $packfield_(storagetype : storagetype, val : val) : fieldval? + def $unpackfield_{vectype : vectype, var_1 : vec_}(V128_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = ?((val : val <: fieldval)) + def $unpackfield_{vectype : vectype, var_1 : vec_}(F64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() - -- otherwise - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? + def $unpackfield_{vectype : vectype, var_1 : vec_}(F32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(I64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(I32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = ?(val) + def $unpackfield_{numtype : numtype, var_0 : num_}(BOT_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) + def $unpackfield_{numtype : numtype, var_0 : num_, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(V128_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(F64_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(F32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(I64_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{sx : sx, i : uN}(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{sx : sx, i : uN}(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- if ($unpackfield_(storagetype, var_0, fieldval) =/= ?()) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.1-190.86 -def $tagsxa(externaddr*) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:196.1-196.23 - def $tagsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:197.1-197.42 - def $tagsxa{a : nat, `xa*` : externaddr*}([TAG_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tagsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:198.1-198.57 - def $tagsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tagsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 +relation fun_tagsxa: `%%`(externaddr*, tagaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([TAG_externaddr(a)] ++ xa#1*{xa#1 <- `xa*`}, [a] ++ var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([externaddr] ++ xa#2*{xa#2 <- `xa*`}, var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.1-191.89 -def $globalsxa(externaddr*) : globaladdr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:200.1-200.26 - def $globalsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:201.1-201.51 - def $globalsxa{a : nat, `xa*` : externaddr*}([GLOBAL_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $globalsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:202.1-202.63 - def $globalsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $globalsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 +relation fun_globalsxa: `%%`(externaddr*, globaladdr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([GLOBAL_externaddr(a)] ++ xa#3*{xa#3 <- `xa*`}, [a] ++ var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([externaddr] ++ xa#4*{xa#4 <- `xa*`}, var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.1-192.86 -def $memsxa(externaddr*) : memaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:204.1-204.23 - def $memsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:205.1-205.42 - def $memsxa{a : nat, `xa*` : externaddr*}([MEM_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $memsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:206.1-206.57 - def $memsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $memsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 +relation fun_memsxa: `%%`(externaddr*, memaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([MEM_externaddr(a)] ++ xa#5*{xa#5 <- `xa*`}, [a] ++ var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([externaddr] ++ xa#6*{xa#6 <- `xa*`}, var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.1-193.88 -def $tablesxa(externaddr*) : tableaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:208.1-208.25 - def $tablesxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:209.1-209.48 - def $tablesxa{a : nat, `xa*` : externaddr*}([TABLE_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tablesxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:210.1-210.61 - def $tablesxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tablesxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 +relation fun_tablesxa: `%%`(externaddr*, tableaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([TABLE_externaddr(a)] ++ xa#7*{xa#7 <- `xa*`}, [a] ++ var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([externaddr] ++ xa#8*{xa#8 <- `xa*`}, var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.1-194.87 -def $funcsxa(externaddr*) : funcaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:212.1-212.24 - def $funcsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:213.1-213.45 - def $funcsxa{a : nat, `xa*` : externaddr*}([FUNC_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $funcsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:214.1-214.59 - def $funcsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $funcsxa(xa*{xa <- `xa*`}) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 +relation fun_funcsxa: `%%`(externaddr*, funcaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([FUNC_externaddr(a)] ++ xa#9*{xa#9 <- `xa*`}, [a] ++ var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([externaddr] ++ xa#10*{xa#10 <- `xa*`}, var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9277,11 +15626,29 @@ def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $store{s : store, f : frame}(`%;%`_state(s, f)) = s +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9292,61 +15659,169 @@ def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst(state : state) : funcinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst(state : state) : datainst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst(state : state) : eleminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst(state : state) : structinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst(state : state) : arrayinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst(state : state) : exninst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fof{z : state}(z) = $frame(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -9357,153 +15832,422 @@ def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $sof{z : state}(z) = $store(z) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag(state : state, tagidx : tagidx) : taginst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global(state : state, globalidx : globalidx) : globalinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem(state : state, memidx : memidx) : meminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $table(state : state, tableidx : tableidx) : tableinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] + def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $func(state : state, funcidx : funcidx) : funcinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $data(state : state, dataidx : dataidx) : datainst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $elem(state : state, tableidx : tableidx) : eleminst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $local(state : state, localidx : localidx) : val? + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_local(state : state, localidx : localidx, val : val) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_global(state : state, globalidx : globalidx, val : val) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b#1*{b#1 <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_elem(state : state, elemidx : elemidx, ref*) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r#1*{r#1 <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $with_data(state : state, dataidx : dataidx, byte*) : state + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#2*{b#2 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $func(state : state, funcidx : funcidx) : funcinst +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $data(state : state, dataidx : dataidx) : datainst +def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] + def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $elem(state : state, tableidx : tableidx) : eleminst +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $local(state : state, localidx : localidx) : val? +def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] + def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_local(state : state, localidx : localidx, val : val) : state +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_global(state : state, globalidx : globalidx, val : val) : state +def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + def $add_structinst{z : state, `si*` : structinst*}(z, si#1*{si#1 <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state +def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai#1*{ai#1 <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state +def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + def $add_exninst{z : state, `exn*` : exninst*}(z, exn#1*{exn#1 <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_elem(state : state, elemidx : elemidx, ref*) : state +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_data(state : state, dataidx : dataidx, byte*) : state +relation fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%`(tableinst, n, r) + -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state +relation fun_growtable: `%%%%`(tableinst, nat, ref, tableinst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + rule fun_growtable_case_1{x0 : tableinst, x1 : nat, x2 : ref}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_growtable_before_fun_growtable_case_1: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_structinst(state : state, structinst*) : state +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst, var_0 : tableinst?}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(ret_val) + -- fun_growtable: `%%%%`(tableinst, nat, ref, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_arrayinst(state : state, arrayinst*) : state +relation fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%`(meminst, n) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_exninst(state : state, exninst*) : state +relation fun_growmem: `%%%`(meminst, nat, meminst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}(tableinst, n, r) = ?(tableinst') - -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}} = tableinst - -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - -- if ($proj_uN_0(i').0 = (|r'*{r' <- `r'*`}| + n)) - -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j).0))?{j <- `j?`} - -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise + rule fun_growmem_case_1{x0 : meminst, x1 : nat}: + `%%%`(x0, x1, ?()) + -- ~ fun_growmem_before_fun_growmem_case_1: `%%`(x0, x1) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(meminst : meminst, nat : nat) : meminst? +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) - -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j).0))?{j <- `j?`} - -- if ($proj_uN_0(i').0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst, var_0 : meminst?}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(ret_val) + -- fun_growmem: `%%%`(meminst, nat, var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -9542,36 +16286,36 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.STRUCTS_store|) + `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) + -- if (a < |s.STRUCTS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.ARRAYS_store|) + `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) + -- if (a < |s.ARRAYS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.FUNCS_store|) + `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) + -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) @@ -9612,21 +16356,21 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) relation Val_ok: `%|-%:%`(store, val, valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule num{s : store, num : num, nt : numtype}: - `%|-%:%`(s, (num : num <: val), (nt : numtype <: valtype)) + `%|-%:%`(s, $val_num(num), $valtype_numtype(nt)) -- Num_ok: `%|-%:%`(s, num, nt) -- wf_store: `%`(s) -- wf_num: `%`(num) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule vec{s : store, vec : vec, vt : vectype}: - `%|-%:%`(s, (vec : vec <: val), (vt : vectype <: valtype)) + `%|-%:%`(s, $val_vec(vec), $valtype_vectype(vt)) -- Vec_ok: `%|-%:%`(s, vec, vt) -- wf_store: `%`(s) -- wf_vec: `%`(vec) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule ref{s : store, ref : ref, rt : reftype}: - `%|-%:%`(s, (ref : ref <: val), (rt : reftype <: valtype)) + `%|-%:%`(s, $val_ref(ref), $valtype_reftype(rt)) -- Ref_ok: `%|-%:%`(s, ref, rt) -- wf_store: `%`(s) -- wf_ref: `%`(ref) @@ -9644,7 +16388,7 @@ relation Packval_ok: `%|-%:%`(store, packval, packtype) relation Fieldval_ok: `%|-%:%`(store, fieldval, storagetype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule val{s : store, val : val, t : valtype}: - `%|-%:%`(s, (val : val <: fieldval), (t : valtype <: storagetype)) + `%|-%:%`(s, $fieldval_val(val), $storagetype_valtype(t)) -- Val_ok: `%|-%:%`(s, val, t) -- wf_store: `%`(s) -- wf_val: `%`(val) @@ -9652,7 +16396,7 @@ relation Fieldval_ok: `%|-%:%`(store, fieldval, storagetype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule packval{s : store, packval : packval, pt : packtype}: - `%|-%:%`(s, (packval : packval <: fieldval), (pt : packtype <: storagetype)) + `%|-%:%`(s, $fieldval_packval(packval), $storagetype_packtype(pt)) -- Packval_ok: `%|-%:%`(s, packval, pt) -- wf_store: `%`(s) -- wf_packval: `%`(packval) @@ -9665,42 +16409,42 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 rule tag{s : store, a : addr, taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) + -- if (a < |s.TAGS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 rule global{s : store, a : addr, globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) + -- if (a < |s.GLOBALS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 rule mem{s : store, a : addr, meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) + -- if (a < |s.MEMS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 rule table{s : store, a : addr, tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) + -- if (a < |s.TABLES_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, funcinst : funcinst}: - `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) - -- if (a < |s.FUNCS_store|) + `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) -- if (s.FUNCS_store[a] = funcinst) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) - -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:126.1-130.37 rule sub{s : store, externaddr : externaddr, xt : externtype, xt' : externtype}: @@ -9715,35 +16459,100 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) } ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype +relation fun_inst_valtype: `%%%`(moduleinst, valtype, valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_valtype_case_0{moduleinst : moduleinst, t : valtype, var_0 : valtype}: + `%%%`(moduleinst, t, var_0) + -- fun_subst_all_valtype: `%%%`(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_inst_valtype: `%%%`(moduleinst, valtype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_reftype: `%%%`(moduleinst, reftype, reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_reftype_case_0{moduleinst : moduleinst, rt : reftype, var_0 : reftype}: + `%%%`(moduleinst, rt, var_0) + -- fun_subst_all_reftype: `%%%`(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype, var_0 : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_reftype: `%`(ret_val) + -- fun_inst_reftype: `%%%`(moduleinst, reftype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_globaltype: `%%%`(moduleinst, globaltype, globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_globaltype_case_0{moduleinst : moduleinst, gt : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, gt, var_0) + -- fun_subst_all_globaltype: `%%%`(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_globaltype: `%`(ret_val) + -- fun_inst_globaltype: `%%%`(moduleinst, globaltype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype +relation fun_inst_memtype: `%%%`(moduleinst, memtype, memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule fun_inst_memtype_case_0{moduleinst : moduleinst, mt : memtype, var_0 : memtype}: + `%%%`(moduleinst, mt, var_0) + -- fun_subst_all_memtype: `%%%`(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype, var_0 : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_memtype: `%`(ret_val) + -- fun_inst_memtype: `%%%`(moduleinst, memtype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype +relation fun_inst_tabletype: `%%%`(moduleinst, tabletype, tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule fun_inst_tabletype_case_0{moduleinst : moduleinst, tt : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tt, var_0) + -- fun_subst_all_tabletype: `%%%`(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_tabletype: `%`(ret_val) + -- fun_inst_tabletype: `%%%`(moduleinst, tabletype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-null_0`{ref_1 : ref, ref_2 : ref}: - `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) @@ -9766,15 +16575,15 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule drop{val : val}: - `%~>%`([(val : val <: instr) DROP_instr], []) + `%~>%`([$instr_val(val) DROP_instr], []) -- wf_val: `%`(val) -- wf_instr: `%`(DROP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_1 : val <: instr)]) - -- if ($proj_num__0(c) =/= ?()) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9782,9 +16591,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_2 : val <: instr)]) - -- if ($proj_num__0(c) =/= ?()) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_2)]) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9793,8 +16602,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) -- wf_instr: `%`(BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})) @@ -9802,41 +16611,42 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) -- wf_instr: `%`(BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `label-vals`{n : n, `instr*` : instr*, `val*` : val*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})) + `%~>%`([`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, $instr_val(val)*{val <- `val*`})], $instr_val(val)*{val <- `val*`}) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-zero`{n : n, `instr'*` : instr*, `val'*` : val*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) -- if ($proj_uN_0(l).0 = 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) -- if ($proj_uN_0(l).0 > 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-handler`{n : n, `catch*` : catch*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-true`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) @@ -9844,8 +16654,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-false`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -9861,15 +16671,15 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l')) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [BR_instr(l)]) + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [BR_instr(l)]) -- if (val = `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) @@ -9878,14 +16688,14 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [(val : val <: instr)]) + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [$instr_val(val)]) -- if (val =/= `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_non_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], []) + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], []) -- if (val = `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -9893,7 +16703,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_non_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], [(val : val <: instr) BR_instr(l)]) + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], [$instr_val(val) BR_instr(l)]) -- if (val =/= `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -9901,50 +16711,52 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call_indirect{x : idx, yy : typeuse}: - `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) CALL_REF_instr(yy)]) + `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) CALL_REF_instr(yy)]) -- wf_instr: `%`(CALL_INDIRECT_instr(x, yy)) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) + -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_indirect{x : idx, yy : typeuse}: - `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) RETURN_CALL_REF_instr(yy)]) + `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) RETURN_CALL_REF_instr(yy)]) -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, yy)) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) + -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `frame-vals`{n : n, f : frame, `val*` : val*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})) + `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})], $instr_val(val)^n{val <- `val*`}) + -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`}) + -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [RETURN_instr]) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(RETURN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-handler`{n : n, `catch*` : catch*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [RETURN_instr]) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(RETURN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `handler-vals`{n : n, `catch*` : catch*, `val*` : val*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`})], $instr_val(val)*{val <- `val*`}) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `trap-instrs`{`val*` : val*, `instr*` : instr*}: - `%~>%`((val : val <: instr)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) + `%~>%`($instr_val(val)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) -- (wf_val: `%`(val))*{val <- `val*`} -- (wf_instr: `%`(instr))*{instr <- `instr*`} @@ -9970,7 +16782,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.tee`{val : val, x : idx}: - `%~>%`([(val : val <: instr) `LOCAL.TEE`_instr(x)], [(val : val <: instr) (val : val <: instr) `LOCAL.SET`_instr(x)]) + `%~>%`([$instr_val(val) `LOCAL.TEE`_instr(x)], [$instr_val(val) $instr_val(val) `LOCAL.SET`_instr(x)]) -- wf_val: `%`(val) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) @@ -9978,14 +16790,14 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.i31`{i : num_}: `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`REF.I31`_instr) -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.is_null-true`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) @@ -9994,7 +16806,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.is_null-false`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) @@ -10002,7 +16814,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.as_non_null-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [TRAP_instr]) + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [TRAP_instr]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) @@ -10011,14 +16823,14 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.as_non_null-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [(ref : ref <: instr)]) + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [$instr_ref(ref)]) -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-null`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) @@ -10028,7 +16840,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-true`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) -- if (ref_1 = ref_2) -- wf_ref: `%`(ref_1) @@ -10038,7 +16850,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-false`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) -- if (ref_1 =/= ref_2) -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) @@ -10062,7 +16874,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new`{val : val, n : n, x : idx}: - `%~>%`([(val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW`_instr(x)], (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + `%~>%`([$instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW`_instr(x)], $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- wf_val: `%`(val) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) @@ -10070,7 +16882,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `extern.convert_any-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) @@ -10078,7 +16890,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `extern.convert_any-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) @@ -10091,51 +16903,60 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `any.convert_extern-addr`{ref : ref}: - `%~>%`([`REF.EXTERN`_instr(ref) `ANY.CONVERT_EXTERN`_instr], [(ref : ref <: instr)]) + `%~>%`([`REF.EXTERN`_instr(ref) `ANY.CONVERT_EXTERN`_instr], [$instr_ref(ref)]) -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: + rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (|$unop_(nt, unop, c_1)| > 0) - -- if (c <- $unop_(nt, unop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: + rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) - -- if ($unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: + rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: + rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) - -- if ($binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10143,35 +16964,41 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: + rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (|$cvtop__(nt_1, nt_2, cvtop, c_1)| > 0) - -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: + rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10179,8 +17006,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -10189,8 +17017,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10200,132 +17029,160 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: + rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $vunop_(sh, vunop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: + rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) - -- if ($vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: + rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: + rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: + rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vternop_(sh, vternop, c_1, c_2, c_3)| > 0) - -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: + rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) - -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, var_0 : nat}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) + -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) -- if ($proj_num__0(c) =/= ?()) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`})) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) + -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- fun_prod: `%%`($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: + rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vrelop_: `%%%%%`(sh, vrelop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: + rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshiftop_: `%%%%%`(sh, vshiftop, c_1, !($proj_num__0(i)), var_0) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: + rule vbitmask{c_1 : vec_, sh : ishape, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) + -- if (!($proj_num__0(c)) = var_0) -- if ($proj_num__0(c) =/= ?()) - -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- fun_vbitmaskop_: `%%%`(sh, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: + rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vswizzlop_: `%%%%%`(sh, swizzlop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: + rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshufflop_: `%%%%%`(sh, i*{i <- `i*`}, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10333,31 +17190,37 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)|) - -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) + -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)|) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) - -- wf_shape: `%`(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) + -- wf_shape: `%`(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) + -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) -- if ($proj_num__0(c_2) =/= ?()) - -- if ($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)|) - -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)|) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) - -- wf_shape: `%`(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -10365,76 +17228,102 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape(Lnn, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: + rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextunop__: `%%%%%`(sh_1, sh_2, vextunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: + rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextbinop__: `%%%%%%`(sh_1, sh_2, vextbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: + rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VEXTTERNOP_instr(sh_2, sh_1, vextternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextternop__: `%%%%%%%`(sh_1, sh_2, vextternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: + rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vnarrowop__: `%%%%%%`($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: + rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vcvtop__: `%%%%%`(sh_1, sh_2, vcvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -def $blocktype_(state : state, blocktype : blocktype) : instrtype +relation fun_blocktype_: `%%%`(state, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + rule fun_blocktype__case_0{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%`(z, _IDX_blocktype(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#2*{t_1#2 <- `t_1*`}), `%`_resulttype(t_2#2*{t_2#2 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule fun_blocktype__case_1{z : state, `t?` : valtype?}: + `%%%`(z, _RESULT_blocktype(t#1?{t#1 <- `t?`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype, var_0 : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_instrtype: `%`(ret_val) + -- fun_blocktype_: `%%%`(state, blocktype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_throw_ref-handler-next`: `%`(config) @@ -10454,11 +17343,12 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$exninst(z)|) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10466,11 +17356,12 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$exninst(z)|) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10478,163 +17369,203 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) relation `Step_read_before_table.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_memory.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_memory.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_memory.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.test-false`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_array.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.fill-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10642,18 +17573,20 @@ relation `Step_read_before_array.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10669,18 +17602,20 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10691,10 +17626,10 @@ relation `Step_read_before_array.copy-gt`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) -- if ($sx(zt_2) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -10718,18 +17653,20 @@ relation `Step_read_before_array.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10738,17 +17675,47 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_array.init_elem-succ`: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-zero_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (n = 0) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10758,9 +17725,10 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10768,9 +17736,10 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10787,9 +17756,10 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10797,65 +17767,81 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) + rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) + rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast_fail-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- ~ `Step_read_before_br_on_cast_fail-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) + -- ~ `Step_read_before_br_on_cast_fail-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) + -- wf_instr: `%`(CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-null`{z : state, yy : typeuse}: @@ -10865,56 +17851,65 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) - -- if (a < |$funcinst(z)|) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) -- if ($funcinst(z)[a] = fi) + -- if (a < |$funcinst(z)|) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) + -- (if ($default_(t) =/= ?()))*{t <- `t*`} + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if (a < |$funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) + -- wf_instr: `%`(RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-label`{z : state, k : n, `instr'*` : instr*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-handler`{z : state, k : n, `catch*` : catch*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-null`{z : state, k : n, f : frame, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) - -- if (a < |$funcinst(z)|) + `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + -- if (a < |$funcinst(z)|) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-null`{z : state}: @@ -10924,9 +17919,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-instrs`{z : state, `val*` : val*, a : addr, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) + `%~>%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(THROW_REF_instr) @@ -10953,23 +17948,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$exninst(z)|) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$exninst(z)|) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10995,413 +17992,462 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) + rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) + `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `global.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) + `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0] : ref <: instr)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [$instr_ref($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) -- if ($proj_num__0(i) =/= ?()) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: - `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) + `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), []) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), []) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_2) =/= ?()) - -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))]) -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) - -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($proj_num__0(i) =/= ?()))^(k%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[(($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.size`{z : state, x : idx, at : addrtype, n : n, lim : limits}: - `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) + `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) -- if (n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) -- if (n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0)))) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) @@ -11415,45 +18461,51 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.func`{z : state, x : idx}: `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.test-false`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.cast-fail`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [TRAP_instr]) - -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [TRAP_instr]) + -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), (val : val <: instr)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) + `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- if (|`val*`| = |`zt*`|) -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- `zt*`} - -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11466,22 +18518,26 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])) : val <: instr)]) + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) + -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) -- if ($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) -- if (a < |$structinst(z)|) - -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) + -- if ($default_($unpack(zt)) =/= ?()) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11489,27 +18545,31 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), $instr_ref(ref)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) + -- if ($proj_num__0(i) =/= ?()) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- if (n = |`ref*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) -- if ($proj_num__0(i) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11517,15 +18577,21 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- (if ($cunpack(zt) =/= ?()))^n{} -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if ($zsize(zt) =/= ?()) -- if ($proj_num__0(i) =/= ?()) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (if ($cunpack(zt) =/= ?()))^n{} + -- (wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (n = |`c*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -11536,20 +18602,23 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])) : val <: instr)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) -- if ($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) -- if (a < |$arrayinst(z)|) -- if ($proj_num__0(i) =/= ?()) - -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11562,104 +18631,94 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-array`{z : state, a : addr}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) - -- if (a < |$arrayinst(z)|) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) + -- if (a < |$arrayinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-null`{z : state, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (n =/= 0) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-null1`{z : state, i_1 : num_, ref : ref, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-null2`{z : state, ref : ref, i_1 : num_, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-zero`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.copy-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) + -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if (n =/= 0) - -- if (a_2 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (a_1 < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$arrayinst(z)[a_1].FIELDS_arrayinst|) - -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- if ($sx(zt_2) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -11676,17 +18735,17 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) -- ~ `Step_read_before_array.copy-gt`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ($sx(zt_2) =/= ?()) -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) + -- if ($sx(zt_2) =/= ?()) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_1) =/= ?()) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_2) =/= ?()) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -11704,48 +18763,44 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-zero`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ($proj_num__0(j) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- ~ `Step_read_before_array.init_elem-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (n = 0) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if (n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|) - -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_ref(ref) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) + -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) @@ -11759,9 +18814,10 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11769,9 +18825,10 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11786,19 +18843,23 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- if ($cunpack(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) -- ~ `Step_read_before_array.init_data-num`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(j) =/= ?()) + -- if ($zsize(zt) =/= ?()) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- if ($cunpack(zt) =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) @@ -11825,11 +18886,11 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:32.1-35.41 rule `ctxt-instrs`{z : state, `val*` : val*, `instr*` : instr*, `instr_1*` : instr*, z' : state, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) + `%~>%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`}), `%;%`_config(z', $instr_val(val)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) -- if ((val*{val <- `val*`} =/= []) \/ (instr_1*{instr_1 <- `instr_1*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) @@ -11862,58 +18923,68 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) -- if (a = |$exninst(z)|) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (n = |`val*`|) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule `local.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_local(z, x, val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:318.1-319.58 rule `global.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_global(z, x, val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 - rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) - -- if (ti = !($growtable($table(z, x), n, ref))) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_0 : tableinst?}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- if (ti = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(!(var_0)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:352.1-353.87 - rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) + rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:413.1-414.51 rule `elem.drop`{z : state, x : idx}: @@ -11923,87 +18994,100 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) -- if ($proj_num__0(c) =/= ?()) - -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c)))) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if ($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) - -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)|) - -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) + -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)|) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) + -- if ($proj_num__0(i) =/= ?()) + -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 - rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) - -- if (mi = !($growmem($mem(z, x), n))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_0 : meminst?}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- if (mi = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(!(var_0)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- fun_growmem: `%%%`($mem(z, x), n, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:554.1-555.84 - rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) + rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:615.1-616.51 rule `data.drop`{z : state, x : idx}: @@ -12013,66 +19097,73 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:692.1-696.65 rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) + -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- if (n = |`val*`|) + -- if (n = |`mut?*`|) + -- if (n = |`zt*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(val) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) - -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) + -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:732.1-737.65 rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) + -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) - -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($packfield_(zt, val) =/= ?()) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($packfield_(zt, val) =/= ?()) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) } @@ -12101,355 +19192,777 @@ relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule _{z : state, `instr*` : instr*, z' : state, `val*` : val*}: `%;%~>*%;%`(z, instr*{instr <- `instr*`}, z', val*{val <- `val*`}) - -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`})) + -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', $instr_val(val)*{val <- `val*`})) -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.1-7.63 -def $alloctypes(type*) : deftype* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:8.1-8.27 - def $alloctypes([]) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:9.1-13.24 - def $alloctypes{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN}(type'*{type' <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} - -- let{`deftype'*` : deftype*} deftype'*{deftype' <- `deftype'*`} = $alloctypes(type'*{type' <- `type'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 +relation fun_alloctypes: `%%`(type*, deftype*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- let{`deftype'*` : deftype*} deftype'#1*{deftype'#1 <- `deftype'*`} = var_0 -- let{rectype : rectype} TYPE_type(rectype) = type - -- if (deftype*{deftype <- `deftype*`} = $subst_all_deftypes($rolldt(x, rectype), (deftype' : deftype <: typeuse)*{deftype' <- `deftype'*`})) - -- if ($proj_uN_0(x).0 = |deftype'*{deftype' <- `deftype'*`}|) + -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) + -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) -- wf_uN: `%%`(32, x) + -- fun_rolldt: `%%%`(x, rectype, var_2) + -- fun_subst_all_deftypes: `%%%`(var_2, $typeuse_deftype(deftype'#2)*{deftype'#2 <- `deftype'*`}, var_1) + -- fun_alloctypes: `%%`(type'#2*{type'#2 <- `type'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) +relation fun_alloctag: `%%%`(store, tagtype, (store, tagaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) + rule fun_alloctag_case_0{s : store, tagtype : typeuse, taginst : taginst}: + `%%%`(s, tagtype, (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|)) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr), var_0 : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctag: `%%%`(store, tagtype, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- let{ja : tagaddr, s_1 : store} (s_1, ja) = var_0 + -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = var_1 + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.1-20.102 -def $alloctags(store : store, tagtype*) : (store, tagaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:21.1-21.34 - def $alloctags{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:22.1-24.49 - def $alloctags{s : store, tagtype : typeuse, `tagtype'*` : tagtype*}(s, [tagtype] ++ tagtype'*{tagtype' <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) - -- let{ja : tagaddr, s_1 : store} (s_1, ja) = $alloctag(s, tagtype) - -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*), var_1 : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_alloctags: `%%%`(store, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) +relation fun_allocglobal: `%%%%`(store, globaltype, val, (store, globaladdr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) + rule fun_allocglobal_case_0{s : store, globaltype : globaltype, val : val, globalinst : globalinst}: + `%%%%`(s, globaltype, val, (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|)) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr), var_0 : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobal: `%%%%`(store, globaltype, val, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation fun_allocglobals: `%%%%`(store, globaltype*, val*, (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: + `%%%%`(s, [globaltype] ++ globaltype'#1*{globaltype'#1 <- `globaltype'*`}, [val] ++ val'#1*{val'#1 <- `val'*`}, (s_2, [ga] ++ ga'*{ga' <- `ga'*`})) + -- let{ga : globaladdr, s_1 : store} (s_1, ga) = var_0 + -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1 + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*), var_2 : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobals: `%%%%`(store, var_0, var_1, var_2) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocmem: `%%%`(store, memtype, (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocmem_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}: + `%%%`(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`})), (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|)) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr), var_0 : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocmem: `%%%`(store, memtype, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- let{ma : memaddr, s_1 : store} (s_1, ma) = var_0 + -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = var_1 + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*), var_1 : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocmems: `%%%`(store, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_alloctable: `%%%%`(store, tabletype, ref, (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_alloctable_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}: + `%%%%`(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|)) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr), var_0 : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctable: `%%%%`(store, tabletype, ref, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation fun_alloctables: `%%%%`(store, tabletype*, ref*, (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: + `%%%%`(s, [tabletype] ++ tabletype'#1*{tabletype'#1 <- `tabletype'*`}, [ref] ++ ref'#1*{ref'#1 <- `ref'*`}, (s_2, [ta] ++ ta'*{ta' <- `ta'*`})) + -- let{ta : tableaddr, s_1 : store} (s_1, ta) = var_0 + -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1 + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*), var_2 : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_alloctables: `%%%%`(store, var_0, var_1, var_2) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocfunc_case_0{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}: + `%%%%%`(s, deftype, funccode, moduleinst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|)) + -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) + -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr), var_0 : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, var_0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.1-31.122 -def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:32.1-32.42 - def $allocglobals{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:33.1-35.62 - def $allocglobals{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*}(s, [globaltype] ++ globaltype'*{globaltype' <- `globaltype'*`}, [val] ++ val'*{val' <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) - -- let{ga : globaladdr, s_1 : store} (s_1, ga) = $allocglobal(s, globaltype, val) - -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_0{s : store}: + `%%%%%`(s, [], [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_1{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*, var_1 : (store, funcaddr*), var_0 : (store, funcaddr)}: + `%%%%%`(s, [dt] ++ dt'#3*{dt'#3 <- `dt'*`}, [funccode] ++ funccode'#1*{funccode'#1 <- `funccode'*`}, [moduleinst] ++ moduleinst'#1*{moduleinst'#1 <- `moduleinst'*`}, (s_2, [fa] ++ fa'*{fa' <- `fa'*`})) + -- let{fa : funcaddr, s_1 : store} (s_1, fa) = var_0 + -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1 + -- fun_allocfuncs: `%%%%%`(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}, var_1) + -- fun_allocfunc: `%%%%%`(s, dt, funccode, moduleinst, var_0) } -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(store : store, memtype : memtype) : (store, memaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) - -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.1-42.102 -def $allocmems(store : store, memtype*) : (store, memaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:43.1-43.34 - def $allocmems{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:44.1-46.49 - def $allocmems{s : store, memtype : memtype, `memtype'*` : memtype*}(s, [memtype] ++ memtype'*{memtype' <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) - -- let{ma : memaddr, s_1 : store} (s_1, ma) = $allocmem(s, memtype) - -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*), var_3 : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = var_3) + -- wf_store: `%`(ret_val.0) + -- fun_allocfuncs: `%%%%%`(store, var_0, var_1, var_2, var_3) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) +relation fun_allocdata: `%%%%`(store, datatype, byte*, (store, dataaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) - -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + rule fun_allocdata_case_0{s : store, `byte*` : byte*, datainst : datainst}: + `%%%%`(s, OK_datatype, byte#2*{byte#2 <- `byte*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|)) + -- if (datainst = {BYTES byte#3*{byte#3 <- `byte*`}}) + -- wf_datainst: `%`({BYTES byte#4*{byte#4 <- `byte*`}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr), var_1 : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocdata: `%%%%`(store, datatype, var_0, var_1) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.1-53.118 -def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:54.1-54.41 - def $alloctables{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:55.1-57.60 - def $alloctables{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*}(s, [tabletype] ++ tabletype'*{tabletype' <- `tabletype'*`}, [ref] ++ ref'*{ref' <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) - -- let{ta : tableaddr, s_1 : store} (s_1, ta) = $alloctable(s, tabletype, ref) - -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation fun_allocdatas: `%%%%`(store, datatype*, byte**, (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#8*{b#8 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}, (s_2, [da] ++ da'*{da' <- `da'*`})) + -- let{da : dataaddr, s_1 : store} (s_1, da) = var_0 + -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = var_1 + -- fun_allocdatas: `%%%%`(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}, var_1) + -- fun_allocdata: `%%%%`(s, ok, b#9*{b#9 <- `b*`}, var_0) } -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) - -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.1-64.133 -def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funcaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:65.1-65.45 - def $allocfuncs{s : store}(s, [], [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:66.1-68.71 - def $allocfuncs{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*}(s, [dt] ++ dt'*{dt' <- `dt'*`}, [funccode] ++ funccode'*{funccode' <- `funccode'*`}, [moduleinst] ++ moduleinst'*{moduleinst' <- `moduleinst'*`}) = (s_2, [fa] ++ fa'*{fa' <- `fa'*`}) - -- let{fa : funcaddr, s_1 : store} (s_1, fa) = $allocfunc(s, dt, funccode, moduleinst) - -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*), var_2 : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocdatas: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) +relation fun_allocelem: `%%%%`(store, elemtype, ref*, (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocelem_case_0{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}: + `%%%%`(s, elemtype, ref#1*{ref#1 <- `ref*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|)) + -- if (eleminst = {TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) + -- wf_eleminst: `%`({TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) - -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr), var_1 : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocelem: `%%%%`(store, elemtype, var_0, var_1) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.1-75.118 -def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 - def $allocdatas{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'*{ok' <- `ok'*`}, [b*{b <- `b*`}] ++ b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b*{b <- `b*`}) - -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation fun_allocelems: `%%%%`(store, elemtype*, ref**, (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: + `%%%%`(s, [rt] ++ rt'#1*{rt'#1 <- `rt'*`}, [ref#4*{ref#4 <- `ref*`}] ++ ref'#3*{ref'#3 <- `ref'*#1`}*{`ref'*#1` <- `ref'**`}, (s_2, [ea] ++ ea'*{ea' <- `ea'*`})) + -- let{ea : elemaddr, s_1 : store} (s_1, ea) = var_0 + -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1 + -- fun_allocelems: `%%%%`(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}, var_1) + -- fun_allocelem: `%%%%`(s, rt, ref#5*{ref#5 <- `ref*`}, var_0) } -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) - -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.1-86.117 -def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:87.1-87.40 - def $allocelems{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:88.1-90.55 - def $allocelems{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**}(s, [rt] ++ rt'*{rt' <- `rt'*`}, [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = (s_2, [ea] ++ ea'*{ea' <- `ea'*`}) - -- let{ea : elemaddr, s_1 : store} (s_1, ea) = $allocelem(s, rt, ref*{ref <- `ref*`}) - -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*), var_2 : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocelems: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#3*{export#3 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (tag*{tag <- `tag*`} = TAG_tag(tagtype)*{tagtype <- `tagtype*`}) - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (mem*{mem <- `mem*`} = MEMORY_mem(memtype)*{memtype <- `memtype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (func*{func <- `func*`} = FUNC_func(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`}) - -- let{`aa_I*` : tagaddr*} aa_I*{aa_I <- `aa_I*`} = $tagsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ga_I*` : globaladdr*} ga_I*{ga_I <- `ga_I*`} = $globalsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ma_I*` : memaddr*} ma_I*{ma_I <- `ma_I*`} = $memsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ta_I*` : tableaddr*} ta_I*{ta_I <- `ta_I*`} = $tablesxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`fa_I*` : funcaddr*} fa_I*{fa_I <- `fa_I*`} = $funcsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $alloctypes(type*{type <- `type*`}) - -- let{`fa*` : nat*} fa*{fa <- `fa*`} = (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){} - -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa*{aa <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tagtype <- `tagtype*`}) - -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga*{ga <- `ga*`}) = $allocglobals(s_1, $subst_all_globaltype(globaltype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{globaltype <- `globaltype*`}, val_G*{val_G <- `val_G*`}) - -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma*{ma <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{memtype <- `memtype*`}) - -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta*{ta <- `ta*`}) = $alloctables(s_3, $subst_all_tabletype(tabletype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tabletype <- `tabletype*`}, ref_T*{ref_T <- `ref_T*`}) - -- let{s_5 : store, `da*` : dataaddr*} (s_5, da*{da <- `da*`}) = $allocdatas(s_4, OK_datatype^|data*{data <- `data*`}|{}, byte*{byte <- `byte*`}*{`byte*` <- `byte**`}) - -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea*{ea <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{elemtype <- `elemtype*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[$proj_uN_0(x).0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) - -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) - -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_mem: `%`(MEMORY_mem(memtype)))*{memtype <- `memtype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr_F)))*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`} - -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) - -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $rundata_(dataidx : dataidx, data : data) : instr* +relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref**, (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] + rule fun_allocmodule_case_0{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*, var_17 : (store, funcaddr*), `var_16*` : elemtype*, var_15 : (store, elemaddr*), var_14 : (store, dataaddr*), `var_13*` : tabletype*, var_12 : (store, tableaddr*), `var_11*` : memtype*, var_10 : (store, memaddr*), `var_9*` : globaltype*, var_8 : (store, globaladdr*), `var_7*` : tagtype*, var_6 : (store, tagaddr*), var_5 : deftype*, var_4 : funcaddr*, var_3 : tableaddr*, var_2 : memaddr*, var_1 : globaladdr*, var_0 : tagaddr*}: + `%%%%%%%`(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}, (s_7, moduleinst)) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#4*{export#4 <- `export*`})) = module + -- if (tag#3*{tag#3 <- `tag*`} = TAG_tag(tagtype#78)*{tagtype#78 <- `tagtype*`}) + -- if (global#4*{global#4 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) + -- if (mem#4*{mem#4 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) + -- if (table#4*{table#4 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) + -- if (func#4*{func#4 <- `func*`} = FUNC_func(x#2, local#2*{local#2 <- `local*#82`}, expr_F#1)*{expr_F#1 <- `expr_F*`, `local*#82` <- `local**`, x#2 <- `x*`}) + -- if (data#3*{data#3 <- `data*`} = DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`}) + -- if (elem#4*{elem#4 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) + -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = var_0 + -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = var_1 + -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = var_2 + -- let{`ta_I*` : tableaddr*} ta_I#1*{ta_I#1 <- `ta_I*`} = var_3 + -- let{`fa_I*` : funcaddr*} fa_I#1*{fa_I#1 <- `fa_I*`} = var_4 + -- let{`dt*` : deftype*} dt#8*{dt#8 <- `dt*`} = var_5 + -- let{`fa*` : nat*} fa#1*{fa#1 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#5*{func#5 <- `func*`}|){} + -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa#1*{aa#1 <- `aa*`}) = var_6 + -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga#1*{ga#1 <- `ga*`}) = var_8 + -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma#1*{ma#1 <- `ma*`}) = var_10 + -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta#1*{ta#1 <- `ta*`}) = var_12 + -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = var_14 + -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = var_15 + -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = var_17) + -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#5*{export#5 <- `export*`})) + -- if (moduleinst = {TYPES dt#15*{dt#15 <- `dt*`}, TAGS aa_I#3*{aa_I#3 <- `aa_I*`} ++ aa#3*{aa#3 <- `aa*`}, GLOBALS ga_I#3*{ga_I#3 <- `ga_I*`} ++ ga#3*{ga#3 <- `ga*`}, MEMS ma_I#3*{ma_I#3 <- `ma_I*`} ++ ma#3*{ma#3 <- `ma*`}, TABLES ta_I#3*{ta_I#3 <- `ta_I*`} ++ ta#3*{ta#3 <- `ta*`}, FUNCS fa_I#3*{fa_I#3 <- `fa_I*`} ++ fa#4*{fa#4 <- `fa*`}, DATAS da#2*{da#2 <- `da*`}, ELEMS ea#2*{ea#2 <- `ea*`}, EXPORTS xi#2*{xi#2 <- `xi*`}}) + -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) + -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- `tagtype*`} + -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- `expr_G*`, globaltype#125 <- `globaltype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- `memtype*`} + -- (wf_table: `%`(TABLE_table(tabletype#159, expr_T#2)))*{expr_T#2 <- `expr_T*`, tabletype#159 <- `tabletype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_func: `%`(FUNC_func(x#5, local#4*{local#4 <- `local*#85`}, expr_F#3)))*{expr_F#3 <- `expr_F*`, `local*#85` <- `local**`, x#5 <- `x*`} + -- if (|`expr_F*`| = |`local**`|) + -- if (|`expr_F*`| = |`x*`|) + -- (wf_data: `%`(DATA_data(byte#7*{byte#7 <- `byte*#113`}, datamode#112)))*{`byte*#113` <- `byte**`, datamode#112 <- `datamode*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_elem: `%`(ELEM_elem(elemtype#3, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)))*{elemmode#232 <- `elemmode*`, elemtype#3 <- `elemtype*`, `expr_E*#2` <- `expr_E**`} + -- if (|`elemmode*`| = |`elemtype*`|) + -- if (|`elemmode*`| = |`expr_E**`|) + -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#4*{aa_I#4 <- `aa_I*`} ++ aa#4*{aa#4 <- `aa*`}, GLOBALS ga_I#4*{ga_I#4 <- `ga_I*`} ++ ga#4*{ga#4 <- `ga*`}, MEMS ma_I#4*{ma_I#4 <- `ma_I*`} ++ ma#4*{ma#4 <- `ma*`}, TABLES ta_I#4*{ta_I#4 <- `ta_I*`} ++ ta#4*{ta#4 <- `ta*`}, FUNCS fa_I#4*{fa_I#4 <- `fa_I*`} ++ fa#5*{fa#5 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES dt#16*{dt#16 <- `dt*`}, TAGS aa_I#5*{aa_I#5 <- `aa_I*`} ++ aa#5*{aa#5 <- `aa*`}, GLOBALS ga_I#5*{ga_I#5 <- `ga_I*`} ++ ga#5*{ga#5 <- `ga*`}, MEMS ma_I#5*{ma_I#5 <- `ma_I*`} ++ ma#5*{ma#5 <- `ma*`}, TABLES ta_I#5*{ta_I#5 <- `ta_I*`} ++ ta#5*{ta#5 <- `ta*`}, FUNCS fa_I#5*{fa_I#5 <- `fa_I*`} ++ fa#6*{fa#6 <- `fa*`}, DATAS da#3*{da#3 <- `da*`}, ELEMS ea#3*{ea#3 <- `ea*`}, EXPORTS xi#3*{xi#3 <- `xi*`}}) + -- fun_allocfuncs: `%%%%%`(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{}, var_17) + -- (if ($proj_uN_0(x#3).0 < |dt#14*{dt#14 <- `dt*`}|))*{x#3 <- `x*`} + -- (fun_subst_all_reftype: `%%%`(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#2 <- `elemtype*`} + -- if (|`var_16*`| = |`elemtype*`|) + -- fun_allocelems: `%%%%`(s_5, var_16*{var_16 <- `var_16*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_15) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype#158, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#158 <- `tabletype*`} + -- if (|`var_13*`| = |`tabletype*`|) + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- (fun_subst_all_memtype: `%%%`(memtype#124, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#124 <- `memtype*`} + -- if (|`var_11*`| = |`memtype*`|) + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype#124, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#124 <- `globaltype*`} + -- if (|`var_9*`| = |`globaltype*`|) + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- (fun_subst_all_tagtype: `%%%`(tagtype#80, $typeuse_deftype(dt#9)*{dt#9 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#80 <- `tagtype*`} + -- if (|`var_7*`| = |`tagtype*`|) + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#3*{type#3 <- `type*`}, var_5) + -- fun_funcsxa: `%%`(externaddr#6*{externaddr#6 <- `externaddr*`}, var_4) + -- fun_tablesxa: `%%`(externaddr#5*{externaddr#5 <- `externaddr*`}, var_3) + -- fun_memsxa: `%%`(externaddr#4*{externaddr#4 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#3*{externaddr#3 <- `externaddr*`}, var_1) + -- fun_tagsxa: `%%`(externaddr#2*{externaddr#2 <- `externaddr*`}, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst), var_4 : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = var_4) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + -- fun_allocmodule: `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, var_4) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $runelem_(elemidx : elemidx, elem : elem) : instr* +relation fun_rundata_: `%%%`(dataidx, data, instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] + rule fun_rundata__case_0{x : uN, n : nat, `b*` : byte*}: + `%%%`(x, DATA_data(b#10*{b#10 <- `b*`}, PASSIVE_datamode), []) + -- if (n = |`b*`|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule fun_rundata__case_1{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}: + `%%%`(x, DATA_data(b#11*{b#11 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)]) + -- if (n = |`b*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*, var_0 : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_rundata_: `%%%`(dataidx, data, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_runelem_: `%%%`(elemidx, elem, instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_0{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#1*{e#1 <- `e*`}, PASSIVE_elemmode), []) + -- if (n = |`e*`|) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_1{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#2*{e#2 <- `e*`}, DECLARE_elemmode), [`ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_2{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}: + `%%%`(x, ELEM_elem(rt, e#3*{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*, var_0 : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_runelem_: `%%%`(elemidx, elem, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.1-160.92 -def $evalexprs(state : state, expr*) : (state, ref*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:161.1-161.34 - def $evalexprs{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:162.1-165.46 - def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) - -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) - -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) + -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) + -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = var_0 -- wf_state: `%`(z') + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*), var_1 : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} + -- fun_evalexprs: `%%%`(state, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, var_1 : (state, ref**), var_0 : (state, ref*)}: + `%%%`(z, [expr#365*{expr#365 <- `expr*`}] ++ expr'#3*{expr'#3 <- `expr'*#1`}*{`expr'*#1` <- `expr'**`}, (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`})) + -- let{`ref*` : ref*, z' : state} (z', ref#6*{ref#6 <- `ref*`}) = var_0 + -- let{z'' : state, `ref'**` : ref**} (z'', ref'#6*{ref'#6 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`}) = var_1 + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 -def $evalexprss(state : state, expr**) : (state, ref**) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 - def $evalexprss{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:169.1-172.49 - def $evalexprss{z : state, `expr*` : expr*, `expr'**` : expr**}(z, [expr*{expr <- `expr*`}] ++ expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) - -- let{`ref*` : ref*, z' : state} (z', ref*{ref <- `ref*`}) = $evalexprs(z, expr*{expr <- `expr*`}) - -- let{z'' : state, `ref'**` : ref**} (z'', ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = $evalexprss(z', expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**), var_1 : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} + -- fun_evalexprss: `%%%`(state, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 -def $evalglobals(state : state, globaltype*, expr*) : (state, val*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 - def $evalglobals{z : state}(z, [], []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:176.1-181.82 - def $evalglobals{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state}(z, [gt] ++ gt'*{gt' <- `gt'*`}, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [val] ++ val'*{val' <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_0{z : state}: + `%%%%`(z, [], [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state, var_1 : (state, val*), var_0 : (store, globaladdr)}: + `%%%%`(z, [gt] ++ gt'#1*{gt'#1 <- `gt'*`}, [expr] ++ expr'#5*{expr'#5 <- `expr'*`}, (z'', [val] ++ val'*{val' <- `val'*`})) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) -- let{s : store, f : frame} `%;%`_state(s, f) = z' - -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) - -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) + -- let{s' : store, a : addr} (s', a) = var_0 + -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = var_1 -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- fun_evalglobals: `%%%%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, gt, val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*), var_2 : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} + -- fun_evalglobals: `%%%%`(state, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $instantiate(store : store, module : module, externaddr*) : config +relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr*{externaddr <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) - -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- (Externaddr_ok: `%|-%:%`(s, externaddr, xt_I))*{externaddr <- `externaddr*`, xt_I <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`}) - -- if (start?{start <- `start?`} = START_start(x)?{x <- `x?`}) - -- if (moduleinst_0 = {TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat, var_11 : funcaddr*, var_10 : globaladdr*, var_9 : deftype*, `var_8*` : instr**, `var_7*` : instr**, var_6 : (store, moduleinst), var_5 : (state, ref**), var_4 : (state, ref*), var_3 : (state, val*), var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: + `%%%%`(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) + -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) + -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- `externaddr*`, xt_I#2 <- `xt_I*`} + -- if (|`externaddr*`| = |`xt_I*`|) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`})) = module + -- if (global#7*{global#7 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) + -- if (table#7*{table#7 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) + -- if (data#7*{data#7 <- `data*`} = DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`}) + -- if (elem#7*{elem#7 <- `elem*`} = ELEM_elem(reftype#516, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#516 <- `reftype*`}) + -- if (start#6?{start#6 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) + -- if (moduleinst_0 = {TYPES var_0, TAGS [], GLOBALS var_1, MEMS [], TABLES [], FUNCS var_2 ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- let{z' : state, `val_G*` : val*} (z', val_G*{val_G <- `val_G*`}) = $evalglobals(z, globaltype*{globaltype <- `globaltype*`}, expr_G*{expr_G <- `expr_G*`}) - -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T*{ref_T <- `ref_T*`}) = $evalexprs(z', expr_T*{expr_T <- `expr_T*`}) - -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = $evalexprss(z'', expr_E*{expr_E <- `expr_E*`}*{`expr_E*` <- `expr_E**`}) + -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = var_3 + -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T#3*{ref_T#3 <- `ref_T*`}) = var_4 + -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E#3*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`}) = var_5 -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' - -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- let{`instr_D*` : instr*} instr_D*{instr_D <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D), data*{data <- `data*`}[i_D])^(i_D<|data*{data <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) - -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} + -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = var_6 + -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, var_7^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`}) + -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, var_8^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`}) + -- let{`instr_S?` : instr?} instr_S#1?{instr_S#1 <- `instr_S?`} = CALL_instr(x#7)?{x#7 <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`} - -- (wf_start: `%`(START_start(x)))?{x <- `x?`} - -- wf_moduleinst: `%`({TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#3*{xt_I#3 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) + -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#8*{global#8 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#10*{elem#10 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`}))) + -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- `expr_G*`, globaltype#130 <- `globaltype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- `expr_T*`, tabletype#163 <- `tabletype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_data: `%`(DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)))*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_elem: `%`(ELEM_elem(reftype#518, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#518 <- `reftype*`} + -- if (|`elemmode*`| = |`expr_E**`|) + -- if (|`elemmode*`| = |`reftype*`|) + -- (wf_start: `%`(START_start(x#8)))?{x#8 <- `x?`} + -- wf_moduleinst: `%`({TYPES var_9, TAGS [], GLOBALS var_10, MEMS [], TABLES [], FUNCS var_11 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) - -- (wf_uN: `%%`(32, `%`_uN(i_D)))^(i_D<|data*{data <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} - -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} + -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data#11*{data#11 <- `data*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- `x?`} + -- fun_funcsxa: `%%`(externaddr#13*{externaddr#13 <- `externaddr*`}, var_11) + -- fun_globalsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_10) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_9) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#1), elem#9*{elem#9 <- `elem*`}[i_E#1], var_8))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`} + -- (if (i_E#1 < |elem#9*{elem#9 <- `elem*`}|))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1], var_7))^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`} + -- (if (i_D#1 < |data#9*{data#9 <- `data*`}|))^(i_D#1<|data#8*{data#8 <- `data*`}|){} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}, var_6) + -- fun_evalexprss: `%%%`(z'', expr_E#4*{expr_E#4 <- `expr_E*#4`}*{`expr_E*#4` <- `expr_E**`}, var_5) + -- fun_evalexprs: `%%%`(z', expr_T#4*{expr_T#4 <- `expr_T*`}, var_4) + -- fun_evalglobals: `%%%%`(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#10*{externaddr#10 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config, var_1 : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_instantiate: `%%%%`(store, module, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_invoke: `%%%%`(store, funcaddr, val*, config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_invoke_case_0{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%%`(s, funcaddr, val#1*{val#1 <- `val*`}, `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- if (funcaddr < |s.FUNCS_store|) + -- (Val_ok: `%|-%:%`(s, val#2, t_1#5))*{t_1#5 <- `t_1*`, val#2 <- `val*`} + -- if (|`t_1*`| = |`val*`|) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config, var_1 : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_invoke: `%%%%`(store, funcaddr, var_0, var_1) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -12469,6 +19982,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -12509,13 +20030,30 @@ syntax I = idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.1-154.56 -def $concat_idctxt(idctxt*) : idctxt - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 - def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 - def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation fun_concat_idctxt: `%%`(idctxt*, idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_0: + `%%`([], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_1{I : idctxt, `I'*` : I*, var_0 : idctxt}: + `%%`([I] ++ I'#1*{I'#1 <- `I'*`}, I +++ var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt, var_1 : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_idctxt: `%`(ret_val) + -- fun_concat_idctxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -12536,6 +20074,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12555,6 +20104,39 @@ syntax decl = | START(funcidx : funcidx) | EXPORT(name : name, externidx : externidx) +def $decl_data(data) : decl + def $decl_data{x0 : byte*, x1 : datamode}(DATA_data(x0, x1)) = DATA_decl(x0, x1) + +def $decl_elem(elem) : decl + def $decl_elem{x0 : reftype, x1 : expr*, x2 : elemmode}(ELEM_elem(x0, x1, x2)) = ELEM_decl(x0, x1, x2) + +def $decl_export(export) : decl + def $decl_export{x0 : name, x1 : externidx}(EXPORT_export(x0, x1)) = EXPORT_decl(x0, x1) + +def $decl_func(func) : decl + def $decl_func{x0 : typeidx, x1 : local*, x2 : expr}(FUNC_func(x0, x1, x2)) = FUNC_decl(x0, x1, x2) + +def $decl_global(global) : decl + def $decl_global{x0 : globaltype, x1 : expr}(GLOBAL_global(x0, x1)) = GLOBAL_decl(x0, x1) + +def $decl_import(import) : decl + def $decl_import{x0 : name, x1 : name, x2 : externtype}(IMPORT_import(x0, x1, x2)) = IMPORT_decl(x0, x1, x2) + +def $decl_mem(mem) : decl + def $decl_mem{x0 : memtype}(MEMORY_mem(x0)) = MEMORY_decl(x0) + +def $decl_start(start) : decl + def $decl_start{x0 : funcidx}(START_start(x0)) = START_decl(x0) + +def $decl_table(table) : decl + def $decl_table{x0 : tabletype, x1 : expr}(TABLE_table(x0, x1)) = TABLE_decl(x0, x1) + +def $decl_tag(tag) : decl + def $decl_tag{x0 : tagtype}(TAG_tag(x0)) = TAG_decl(x0) + +def $decl_type(type) : decl + def $decl_type{x0 : rectype}(TYPE_type(x0)) = TYPE_decl(x0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12624,160 +20206,387 @@ relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.1-258.76 -def $typesd(decl*) : type* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:270.1-270.23 - def $typesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:271.1-271.48 - def $typesd{type : type, `decl'*` : decl*}([(type : type <: decl)] ++ decl'*{decl' <- `decl'*`}) = [type] ++ $typesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:272.1-272.57 - def $typesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $typesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 +relation fun_typesd: `%%`(decl*, type*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_1{rectype : rectype, `decl'*` : decl*, var_0 : type*}: + `%%`([TYPE_decl(rectype)] ++ decl'#1*{decl'#1 <- `decl'*`}, [TYPE_type(rectype)] ++ var_0) + -- fun_typesd: `%%`(decl'#2*{decl'#2 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_2{decl : decl, `decl'*` : decl*, var_0 : type*}: + `%%`([decl] ++ decl'#3*{decl'#3 <- `decl'*`}, var_0) + -- fun_typesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation fun_importsd: `%%`(decl*, import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_1{name : name, name_0 : name, externtype : externtype, `decl'*` : decl*, var_0 : import*}: + `%%`([IMPORT_decl(name, name_0, externtype)] ++ decl'#4*{decl'#4 <- `decl'*`}, [IMPORT_import(name, name_0, externtype)] ++ var_0) + -- fun_importsd: `%%`(decl'#5*{decl'#5 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_2{decl : decl, `decl'*` : decl*, var_0 : import*}: + `%%`([decl] ++ decl'#6*{decl'#6 <- `decl'*`}, var_0) + -- fun_importsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*, var_1 : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} + -- fun_importsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation fun_tagsd: `%%`(decl*, tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_1{tagtype : tagtype, `decl'*` : decl*, var_0 : tag*}: + `%%`([TAG_decl(tagtype)] ++ decl'#7*{decl'#7 <- `decl'*`}, [TAG_tag(tagtype)] ++ var_0) + -- fun_tagsd: `%%`(decl'#8*{decl'#8 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_2{decl : decl, `decl'*` : decl*, var_0 : tag*}: + `%%`([decl] ++ decl'#9*{decl'#9 <- `decl'*`}, var_0) + -- fun_tagsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*, var_1 : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tagsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation fun_globalsd: `%%`(decl*, global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_1{globaltype : globaltype, expr : expr, `decl'*` : decl*, var_0 : global*}: + `%%`([GLOBAL_decl(globaltype, expr)] ++ decl'#10*{decl'#10 <- `decl'*`}, [GLOBAL_global(globaltype, expr)] ++ var_0) + -- fun_globalsd: `%%`(decl'#11*{decl'#11 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_2{decl : decl, `decl'*` : decl*, var_0 : global*}: + `%%`([decl] ++ decl'#12*{decl'#12 <- `decl'*`}, var_0) + -- fun_globalsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*, var_1 : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation fun_memsd: `%%`(decl*, mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_1{memtype : memtype, `decl'*` : decl*, var_0 : mem*}: + `%%`([MEMORY_decl(memtype)] ++ decl'#13*{decl'#13 <- `decl'*`}, [MEMORY_mem(memtype)] ++ var_0) + -- fun_memsd: `%%`(decl'#14*{decl'#14 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_2{decl : decl, `decl'*` : decl*, var_0 : mem*}: + `%%`([decl] ++ decl'#15*{decl'#15 <- `decl'*`}, var_0) + -- fun_memsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*, var_1 : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation fun_tablesd: `%%`(decl*, table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_1{tabletype : tabletype, expr : expr, `decl'*` : decl*, var_0 : table*}: + `%%`([TABLE_decl(tabletype, expr)] ++ decl'#16*{decl'#16 <- `decl'*`}, [TABLE_table(tabletype, expr)] ++ var_0) + -- fun_tablesd: `%%`(decl'#17*{decl'#17 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_2{decl : decl, `decl'*` : decl*, var_0 : table*}: + `%%`([decl] ++ decl'#18*{decl'#18 <- `decl'*`}, var_0) + -- fun_tablesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*, var_1 : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.1-259.78 -def $importsd(decl*) : import* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:274.1-274.25 - def $importsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:275.1-275.56 - def $importsd{import : import, `decl'*` : decl*}([(import : import <: decl)] ++ decl'*{decl' <- `decl'*`}) = [import] ++ $importsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:276.1-276.61 - def $importsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $importsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation fun_funcsd: `%%`(decl*, func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_1{typeidx : typeidx, `local*` : local*, expr : expr, `decl'*` : decl*, var_0 : func*}: + `%%`([FUNC_decl(typeidx, `local*`, expr)] ++ decl'#19*{decl'#19 <- `decl'*`}, [FUNC_func(typeidx, `local*`, expr)] ++ var_0) + -- fun_funcsd: `%%`(decl'#20*{decl'#20 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_2{decl : decl, `decl'*` : decl*, var_0 : func*}: + `%%`([decl] ++ decl'#21*{decl'#21 <- `decl'*`}, var_0) + -- fun_funcsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 -def $tagsd(decl*) : tag* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 - def $tagsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:279.1-279.44 - def $tagsd{tag : tag, `decl'*` : decl*}([(tag : tag <: decl)] ++ decl'*{decl' <- `decl'*`}) = [tag] ++ $tagsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:280.1-280.55 - def $tagsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tagsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*, var_1 : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} + -- fun_funcsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 -def $globalsd(decl*) : global* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 - def $globalsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:283.1-283.56 - def $globalsd{global : global, `decl'*` : decl*}([(global : global <: decl)] ++ decl'*{decl' <- `decl'*`}) = [global] ++ $globalsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:284.1-284.61 - def $globalsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $globalsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation fun_datasd: `%%`(decl*, data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_1{`byte*` : byte*, datamode : datamode, `decl'*` : decl*, var_0 : data*}: + `%%`([DATA_decl(`byte*`, datamode)] ++ decl'#22*{decl'#22 <- `decl'*`}, [DATA_data(`byte*`, datamode)] ++ var_0) + -- fun_datasd: `%%`(decl'#23*{decl'#23 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_2{decl : decl, `decl'*` : decl*, var_0 : data*}: + `%%`([decl] ++ decl'#24*{decl'#24 <- `decl'*`}, var_0) + -- fun_datasd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 -def $memsd(decl*) : mem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 - def $memsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:287.1-287.44 - def $memsd{mem : mem, `decl'*` : decl*}([(mem : mem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [mem] ++ $memsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:288.1-288.55 - def $memsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $memsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*, var_1 : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} + -- fun_datasd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 -def $tablesd(decl*) : table* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 - def $tablesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:291.1-291.52 - def $tablesd{table : table, `decl'*` : decl*}([(table : table <: decl)] ++ decl'*{decl' <- `decl'*`}) = [table] ++ $tablesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:292.1-292.59 - def $tablesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tablesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation fun_elemsd: `%%`(decl*, elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_1{reftype : reftype, `expr*` : expr*, elemmode : elemmode, `decl'*` : decl*, var_0 : elem*}: + `%%`([ELEM_decl(reftype, `expr*`, elemmode)] ++ decl'#25*{decl'#25 <- `decl'*`}, [ELEM_elem(reftype, `expr*`, elemmode)] ++ var_0) + -- fun_elemsd: `%%`(decl'#26*{decl'#26 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_2{decl : decl, `decl'*` : decl*, var_0 : elem*}: + `%%`([decl] ++ decl'#27*{decl'#27 <- `decl'*`}, var_0) + -- fun_elemsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 -def $funcsd(decl*) : func* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 - def $funcsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:295.1-295.48 - def $funcsd{func : func, `decl'*` : decl*}([(func : func <: decl)] ++ decl'*{decl' <- `decl'*`}) = [func] ++ $funcsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:296.1-296.57 - def $funcsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $funcsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*, var_1 : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_elemsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 -def $datasd(decl*) : data* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 - def $datasd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:299.1-299.48 - def $datasd{data : data, `decl'*` : decl*}([(data : data <: decl)] ++ decl'*{decl' <- `decl'*`}) = [data] ++ $datasd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:300.1-300.57 - def $datasd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $datasd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation fun_startsd: `%%`(decl*, start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_1{funcidx : funcidx, `decl'*` : decl*, var_0 : start*}: + `%%`([START_decl(funcidx)] ++ decl'#28*{decl'#28 <- `decl'*`}, [START_start(funcidx)] ++ var_0) + -- fun_startsd: `%%`(decl'#29*{decl'#29 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_2{decl : decl, `decl'*` : decl*, var_0 : start*}: + `%%`([decl] ++ decl'#30*{decl'#30 <- `decl'*`}, var_0) + -- fun_startsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 -def $elemsd(decl*) : elem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 - def $elemsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:303.1-303.48 - def $elemsd{elem : elem, `decl'*` : decl*}([(elem : elem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [elem] ++ $elemsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:304.1-304.57 - def $elemsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $elemsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*, var_1 : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} + -- fun_startsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 -def $startsd(decl*) : start* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 - def $startsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:307.1-307.52 - def $startsd{start : start, `decl'*` : decl*}([(start : start <: decl)] ++ decl'*{decl' <- `decl'*`}) = [start] ++ $startsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:308.1-308.59 - def $startsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $startsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation fun_exportsd: `%%`(decl*, export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_1{name : name, externidx : externidx, `decl'*` : decl*, var_0 : export*}: + `%%`([EXPORT_decl(name, externidx)] ++ decl'#31*{decl'#31 <- `decl'*`}, [EXPORT_export(name, externidx)] ++ var_0) + -- fun_exportsd: `%%`(decl'#32*{decl'#32 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_2{decl : decl, `decl'*` : decl*, var_0 : export*}: + `%%`([decl] ++ decl'#33*{decl'#33 <- `decl'*`}, var_0) + -- fun_exportsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 -def $exportsd(decl*) : export* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 - def $exportsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:311.1-311.56 - def $exportsd{export : export, `decl'*` : decl*}([(export : export <: decl)] ++ decl'*{decl' <- `decl'*`}) = [export] ++ $exportsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:312.1-312.61 - def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*, var_1 : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} + -- fun_exportsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(decl*) : bool +relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl*` : decl*}(decl*{decl <- `decl*`}) = true - -- if ($importsd(decl*{decl <- `decl*`}) = []) + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) + -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl_1*` : decl*, import : import, `decl_2*` : decl*}(decl_1*{decl_1 <- `decl_1*`} ++ [(import : import <: decl)] ++ decl_2*{decl_2 <- `decl_2*`}) = (((((($importsd(decl_1*{decl_1 <- `decl_1*`}) = []) /\ ($tagsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($globalsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($memsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($tablesd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($funcsd(decl_1*{decl_1 <- `decl_1*`}) = [])) + rule fun_ordered_case_1{name : name, name_0 : name, externtype : externtype, `decl_1*` : decl*, `decl_2*` : decl*, var_5 : func*, var_4 : table*, var_3 : mem*, var_2 : global*, var_1 : tag*, var_0 : import*}: + `%%`(decl_1#1*{decl_1#1 <- `decl_1*`} ++ [IMPORT_decl(name, name_0, externtype)] ++ decl_2#1*{decl_2#1 <- `decl_2*`}, ((((((var_0 = []) /\ (var_1 = [])) /\ (var_2 = [])) /\ (var_3 = [])) /\ (var_4 = [])) /\ (var_5 = []))) + -- fun_funcsd: `%%`(decl_1#2*{decl_1#2 <- `decl_1*`}, var_5) + -- fun_tablesd: `%%`(decl_1#3*{decl_1#3 <- `decl_1*`}, var_4) + -- fun_memsd: `%%`(decl_1#4*{decl_1#4 <- `decl_1*`}, var_3) + -- fun_globalsd: `%%`(decl_1#5*{decl_1#5 <- `decl_1*`}, var_2) + -- fun_tagsd: `%%`(decl_1#6*{decl_1#6 <- `decl_1*`}, var_1) + -- fun_importsd: `%%`(decl_1#7*{decl_1#7 <- `decl_1*`}, var_0) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec rule _{C : context, n : n, `dt*` : deftype*, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt_F*` : deftype*, `ok*` : datatype*, `et*` : elemtype*, `lct*` : localtype*, `rt*` : reftype*, `rt'?` : reftype?, `x*` : idx*, m : m, `st*` : subtype*, C_0 : context, `t_1*` : valtype*, `t_2*` : valtype*}: `|-%:OK`(C) - -- if (C = {TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) + -- if (C = {TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- if (C_0 = {TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (Deftype_ok: `%|-%:OK`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} -- if (|`dt_F*`| = |`t_1*`|) -- if (|`dt_F*`| = |`t_2*`|) - -- (Expand: `%~~%`(dt_F, `FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt : reftype <: valtype)])))*{rt <- `rt*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt' : reftype <: valtype)])))?{rt' <- `rt'?`} + -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt)])))*{rt <- `rt*`} + -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt')])))?{rt' <- `rt'?`} -- (if ($proj_uN_0(x).0 < |dt_F*{dt_F <- `dt_F*`}|))*{x <- `x*`} -- wf_context: `%`(C) -- wf_context: `%`(C_0) - -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) + -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (|`t_1*`| = |`t_2*`|) + -- if (n = |`dt*`|) + -- if (m = |`st*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) @@ -12855,33 +20665,33 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) rule _{s : store, `deftype*` : deftype*, `tagaddr*` : tagaddr*, `globaladdr*` : globaladdr*, `memaddr*` : memaddr*, `tableaddr*` : tableaddr*, `funcaddr*` : funcaddr*, `dataaddr*` : dataaddr*, `elemaddr*` : elemaddr*, `exportinst*` : exportinst*, `tagtype*` : tagtype*, `globaltype*` : globaltype*, `memtype*` : memtype*, `tabletype*` : tabletype*, `deftype_F*` : deftype*, `datatype*` : datatype*, `elemtype*` : elemtype*, `subtype*` : subtype*}: `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} - -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} - -- if (|`globaladdr*`| = |`globaltype*`|) + -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} + -- if (|`globaladdr*`| = |`globaltype*`|) + -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} -- if (|`deftype_F*`| = |`funcaddr*`|) - -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} - -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} - -- if (|`tableaddr*`| = |`tabletype*`|) + -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} + -- if (|`tableaddr*`| = |`tabletype*`|) + -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} -- if (|`dataaddr*`| = |`datatype*`|) -- (if (dataaddr < |s.DATAS_store|))*{dataaddr <- `dataaddr*`} - -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} + -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} -- if (|`elemaddr*`| = |`elemtype*`|) -- (if (elemaddr < |s.ELEMS_store|))*{elemaddr <- `elemaddr*`} - -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) - -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} + -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) -- wf_context: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_externtype: `%`(TAG_externtype(tagtype)))*{tagtype <- `tagtype*`} -- (wf_externtype: `%`(GLOBAL_externtype(globaltype)))*{globaltype <- `globaltype*`} - -- (wf_externtype: `%`(FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`} + -- (wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`} -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} @@ -12891,8 +20701,8 @@ relation Frame_ok: `%|-%:%`(store, frame, context) rule _{s : store, `val?*` : val?*, moduleinst : moduleinst, C : context, `lct*` : localtype*}: `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} + -- if (|`lct*`| = |`val?*`|) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_frame: `%`({LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}) @@ -12914,12 +20724,12 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:14.1-16.27 rule ref{s : store, C : context, ref : ref, rt : reftype}: - `%;%|-%:%`(s, C, (ref : ref <: instr), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + `%;%|-%:%`(s, C, $instr_ref(ref), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- Ref_ok: `%|-%:%`(s, ref, rt) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_ref: `%`(ref) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:18.1-21.68 rule label{s : store, C : context, n : n, `instr'*` : instr*, `instr*` : instr*, `t*` : valtype*, `t'*` : valtype*, `x'*` : idx*, `x*` : idx*}: @@ -12933,6 +20743,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) + -- if (n = |`t'*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: @@ -12944,6 +20755,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: @@ -12975,24 +20787,26 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:41.1-45.86 - rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} -- if (|`init*`| = |`t*`|) -- if (|`init*`| = |`x_1*`|) -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} - -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- if ($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}) =/= ?()) - -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- Instrs_ok2: `%;%|-%:%`(s, !(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- if (var_0 =/= ?()) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 rule sub{s : store, C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -13080,14 +20894,14 @@ relation Tableinst_ok: `%|-%:%`(store, tableinst, tabletype) relation Funcinst_ok: `%|-%:%`(store, funcinst, deftype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, dt : deftype, moduleinst : moduleinst, func : func, C : context, dt' : deftype}: - `%|-%:%`(s, {TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}, dt) + `%|-%:%`(s, {TYPE dt, MODULE moduleinst, CODE $funccode_func(func)}, dt) -- Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) -- Func_ok: `%|-%:%`(C, func, dt') -- Deftype_sub: `%|-%<:%`(C, dt', dt) -- wf_store: `%`(s) -- wf_context: `%`(C) - -- wf_funcinst: `%`({TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}) + -- wf_funcinst: `%`({TYPE dt, MODULE moduleinst, CODE $funccode_func(func)}) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -13096,8 +20910,8 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) rule _{s : store, dt : deftype, `fv*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- if (|`fv*`| = |`zt*`|) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} + -- if (|`fv*`| = |`zt*`|) -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -13118,11 +20932,11 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) + -- if ($typeuse_deftype(dt) = s.TAGS_store[ta].TYPE_taginst) -- if (ta < |s.TAGS_store|) - -- if ((dt : deftype <: typeuse) = s.TAGS_store[ta].TYPE_taginst) -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (|`t*`| = |`val*`|) -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} + -- if (|`t*`| = |`val*`|) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -13145,79 +20959,90 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) - -- if (a < |s.STRUCTS_store|) -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (i < |ft*{ft <- `ft*`}|) + -- if (a < |s.STRUCTS_store|) -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) + -- if (i < |ft*{ft <- `ft*`}|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) + -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) - -- if (a < |s.ARRAYS_store|) -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- if (a < |s.ARRAYS_store|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule `ref.exn`{a : addr, s : store, i : nat}: - `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, (s.EXNS_store[a].FIELDS_exninst[i] : val <: fieldval)) - -- if (i < |s.EXNS_store[a].FIELDS_exninst|) - -- if (a < |s.EXNS_store|) + `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) + -- if (i < |s.EXNS_store[a].FIELDS_exninst|) + -- if (a < |s.EXNS_store|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:239.1-240.28 rule `ref.extern`{ref : ref, s : store}: - `%>>_%%`(`REF.EXTERN`_fieldval(ref), s, (ref : ref <: fieldval)) + `%>>_%%`(`REF.EXTERN`_fieldval(ref), s, $fieldval_ref(ref)) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXTERN`_fieldval(ref)) } ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -def $NotImmutReachable(fieldval : fieldval, store : store, fieldval : fieldval) : bool +relation fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = false + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%`(fv_1, s, fv_2) -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +relation fun_NotImmutReachable: `%%%%`(fieldval, store, fieldval, bool) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = true - -- otherwise + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, false) + -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec + rule fun_NotImmutReachable_case_1{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, true) + -- ~ fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fv_1, s, fv_2) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation NotImmutReachable: `~%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{fv_1 : fieldval, s : store, fv_2 : fieldval}: + rule _{fv_1 : fieldval, s : store, fv_2 : fieldval, var_0 : bool}: `~%>>_%%`(fv_1, s, fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) + -- if var_0 -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: `|-%:OK`(s) - -- if (|`taginst*`| = |`tagtype*`|) -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} - -- if (|`globalinst*`| = |`globaltype*`|) + -- if (|`taginst*`| = |`tagtype*`|) -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} - -- if (|`meminst*`| = |`memtype*`|) + -- if (|`globalinst*`| = |`globaltype*`|) -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} - -- if (|`tableinst*`| = |`tabletype*`|) + -- if (|`meminst*`| = |`memtype*`|) -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} - -- if (|`deftype*`| = |`funcinst*`|) + -- if (|`tableinst*`| = |`tabletype*`|) -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} - -- if (|`datainst*`| = |`datatype*`|) + -- if (|`deftype*`| = |`funcinst*`|) -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} - -- if (|`eleminst*`| = |`elemtype*`|) + -- if (|`datainst*`| = |`datatype*`|) -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} + -- if (|`eleminst*`| = |`elemtype*`|) -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} -- (Exninst_ok: `%|-%:OK`(s, exninst))*{exninst <- `exninst*`} @@ -13303,9 +21128,9 @@ relation Extend_structinst: `%<=%`(structinst, structinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?*` : mut?*, `zt*` : storagetype*}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} -- if (|`fv*`| = |`fv'*`|) -- if (|`fv*`| = |`mut?*`|) - -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -13316,8 +21141,8 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) rule _{dt : deftype, `fv*` : fieldval*, `fv'*` : fieldval*, `mut?` : mut?, zt : storagetype}: `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} + -- if (|`fv*`| = |`fv'*`|) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13334,36 +21159,36 @@ relation Extend_store: `%<=%`(store, store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, s' : store}: `%<=%`(s, s') + -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} - -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} + -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} - -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} + -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} - -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} + -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} - -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} + -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} - -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} + -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} - -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} + -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} - -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} + -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} - -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} + -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} - -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} + -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} - -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -13455,8 +21280,8 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -13499,6 +21324,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -13524,6 +21357,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -13532,9 +21374,22 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:33.1-33.57 def $allocXs{syntax X, syntax Y, s : store}(syntax X, syntax Y, s, [], []) = (s, []) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:34.1-36.65 - def $allocXs{syntax X, syntax Y, s : store, X : X, `X'*` : X*, Y : Y, `Y'*` : Y*}(syntax X, syntax Y, s, [X] ++ X'*{X' <- `X'*`}, [Y] ++ Y'*{Y' <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) + def $allocXs{syntax X, syntax Y, s : store, X : X, `X'*` : X*, Y : Y, `Y'*` : Y*}(syntax X, syntax Y, s, [X] ++ X'#1*{X'#1 <- `X'*`}, [Y] ++ Y'#1*{Y'#1 <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) -- let{a : addr, s_1 : store} (s_1, a) = $allocX(syntax X, syntax Y, s, X, Y) - -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) + -- let{s_2 : store, `a'*` : addr*} (s_2, a'#1*{a'#1 <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'#2*{X'#2 <- `X'*`}, Y'#2*{Y'#2 <- `Y'*`}) +} + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) } ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec @@ -13599,7 +21454,8 @@ grammar BsN(N : N) : sN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BiN(N : N) : iN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{i : sN} i:BsN(N) => `%`_iN($inv_signed_(N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:BsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BfN(N : N) : fN @@ -13649,8 +21505,9 @@ grammar Blist(syntax el, grammar BX : el) : el* ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Bname : name ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{name : name, `b*` : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name - -- if ($utf8($proj_name_0(name).0) = b*{b <- `b*`}) + prod{name : name, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name + -- if (var_0 = b*{b <- `b*`}) + -- fun_utf8: `%%`($proj_name_0(name).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Btypeidx : typeidx @@ -13783,11 +21640,11 @@ grammar Breftype : reftype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bvaltype : valtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{nt : numtype} nt:Bnumtype => (nt : numtype <: valtype) + prod{nt : numtype} nt:Bnumtype => $valtype_numtype(nt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{vt : vectype} vt:Bvectype => (vt : vectype <: valtype) + prod{vt : vectype} vt:Bvectype => $valtype_vectype(vt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{rt : reftype} rt:Breftype => (rt : reftype <: valtype) + prod{rt : reftype} rt:Breftype => $valtype_reftype(rt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bresulttype : resulttype @@ -13811,9 +21668,9 @@ grammar Bpacktype : packtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bstoragetype : storagetype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{t : valtype} t:Bvaltype => (t : valtype <: storagetype) + prod{t : valtype} t:Bvaltype => $storagetype_valtype(t) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{pt : packtype} pt:Bpacktype => (pt : packtype <: storagetype) + prod{pt : packtype} pt:Bpacktype => $storagetype_packtype(pt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bfieldtype : fieldtype @@ -15137,10 +22994,11 @@ grammar Bversion : () ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bmodule : module ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**, var_0 : dataidx*} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) -- (if (n = |data*{data <- `data*`}|))?{n <- `n?`} - -- if ((n?{n <- `n?`} =/= ?()) \/ ($dataidx_funcs(func*{func <- `func*`}) = [])) + -- if ((n?{n <- `n?`} =/= ?()) \/ (var_0 = [])) -- (if (func = FUNC_func(typeidx, local*{local <- `local*`}, expr)))*{expr <- `expr*`, func <- `func*`, `local*` <- `local**`, typeidx <- `typeidx*`} + -- fun_dataidx_funcs: `%%`(func*{func <- `func*`}, var_0) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tchar : char @@ -15311,7 +23169,8 @@ grammar Tstringchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tstringelem : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tstringchar => $utf8([c]) + prod{c : char, var_0 : byte*} c:Tstringchar => var_0 + -- fun_utf8: `%%`([c], var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [`%`_byte(((16 * h_1) + h_2))] @@ -15324,8 +23183,9 @@ grammar Tstring : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tname : name ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*, `b*` : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) - -- if (b*{b <- `b*`} = $utf8(c*{c <- `c*`})) + prod{`c*` : char*, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) + -- if (b*{b <- `b*`} = var_0) + -- fun_utf8: `%%`(c*{c <- `c*`}, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tid : name @@ -15489,7 +23349,8 @@ grammar TiN(N : N) : iN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{n : n} `%`_uN(n):TuN(N) => `%`_iN(n) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{i : sN} i:TsN(N) => `%`_iN($inv_signed_(N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:TsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { @@ -15750,11 +23611,11 @@ grammar Treftype_(I : I) : reftype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tvaltype_(I : I) : valtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{nt : numtype} nt:Tnumtype => (nt : numtype <: valtype) + prod{nt : numtype} nt:Tnumtype => $valtype_numtype(nt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{vt : vectype} vt:Tvectype => (vt : vectype <: valtype) + prod{vt : vectype} vt:Tvectype => $valtype_vectype(vt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{rt : reftype} rt:Treftype_(I) => (rt : reftype <: valtype) + prod{rt : reftype} rt:Treftype_(I) => $valtype_reftype(rt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tpacktype : packtype @@ -15766,9 +23627,9 @@ grammar Tpacktype : packtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tstoragetype_(I : I) : storagetype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} t:Tvaltype_(I) => (t : valtype <: storagetype) + prod{t : valtype} t:Tvaltype_(I) => $storagetype_valtype(t) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{pt : packtype} pt:Tpacktype => (pt : packtype <: storagetype) + prod{pt : packtype} pt:Tpacktype => $storagetype_packtype(pt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tfieldtype_(I : I) : fieldtype @@ -15819,7 +23680,8 @@ grammar Ttypedef_(I : I) : (subtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Trectype_(I : I) : (rectype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`st*` : subtype*, `I'*` : I*} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), $concat_idctxt(I'*{I' <- `I'*`})) + prod{`st*` : subtype*, `I'*` : I*, var_0 : idctxt} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Taddrtype : addrtype @@ -15901,7 +23763,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -15972,7 +23834,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -15981,7 +23843,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -17010,9 +24872,10 @@ grammar Tlocal_(I : I) : (local*, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tfunc_(I : I) : (func, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -- if (I' = I +++ I_1 +++ $concat_idctxt(I_2*{I_2 <- `I_2*`})) + prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I, var_0 : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = I +++ I_1 +++ var_0) -- Idctxt_ok: `|-%:OK`(I') + -- fun_concat_idctxt: `%%`(I_2*{I_2 <- `I_2*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdatastring : byte* @@ -17148,46 +25011,59 @@ grammar Telemtable_(I : I) : () ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecl_(I : I) : (decl, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (type, idctxt)} ``:Ttype_(I) => (`` : (type, idctxt) <: (decl, idctxt)) + prod{`` : (type, idctxt)} ``:Ttype_(I) => ($decl_type(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (import, idctxt)} ``:Timport_(I) => (`` : (import, idctxt) <: (decl, idctxt)) + prod{`` : (import, idctxt)} ``:Timport_(I) => ($decl_import(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (tag, idctxt)} ``:Ttag_(I) => (`` : (tag, idctxt) <: (decl, idctxt)) + prod{`` : (tag, idctxt)} ``:Ttag_(I) => ($decl_tag(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (global, idctxt)} ``:Tglobal_(I) => (`` : (global, idctxt) <: (decl, idctxt)) + prod{`` : (global, idctxt)} ``:Tglobal_(I) => ($decl_global(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (mem, idctxt)} ``:Tmem_(I) => (`` : (mem, idctxt) <: (decl, idctxt)) + prod{`` : (mem, idctxt)} ``:Tmem_(I) => ($decl_mem(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (table, idctxt)} ``:Ttable_(I) => (`` : (table, idctxt) <: (decl, idctxt)) + prod{`` : (table, idctxt)} ``:Ttable_(I) => ($decl_table(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (func, idctxt)} ``:Tfunc_(I) => (`` : (func, idctxt) <: (decl, idctxt)) + prod{`` : (func, idctxt)} ``:Tfunc_(I) => ($decl_func(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (data, idctxt)} ``:Tdata_(I) => (`` : (data, idctxt) <: (decl, idctxt)) + prod{`` : (data, idctxt)} ``:Tdata_(I) => ($decl_data(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (elem, idctxt)} ``:Telem_(I) => (`` : (elem, idctxt) <: (decl, idctxt)) + prod{`` : (elem, idctxt)} ``:Telem_(I) => ($decl_elem(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (start, idctxt)} ``:Tstart_(I) => (`` : (start, idctxt) <: (decl, idctxt)) + prod{`` : (start, idctxt)} ``:Tstart_(I) => ($decl_start(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (export, idctxt)} ``:Texport_(I) => (`` : (export, idctxt) <: (decl, idctxt)) + prod{`` : (export, idctxt)} ``:Texport_(I) => ($decl_export(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tmodule : module ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) - -- if (I' = $concat_idctxt(I*{I <- `I*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I, var_12 : bool, var_11 : export*, var_10 : start*, var_9 : elem*, var_8 : data*, var_7 : func*, var_6 : table*, var_5 : mem*, var_4 : global*, var_3 : tag*, var_2 : import*, var_1 : type*, var_0 : idctxt} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + -- if (I' = var_0) -- Idctxt_ok: `|-%:OK`(I') - -- if (type*{type <- `type*`} = $typesd(decl*{decl <- `decl*`})) - -- if (import*{import <- `import*`} = $importsd(decl*{decl <- `decl*`})) - -- if (tag*{tag <- `tag*`} = $tagsd(decl*{decl <- `decl*`})) - -- if (global*{global <- `global*`} = $globalsd(decl*{decl <- `decl*`})) - -- if (mem*{mem <- `mem*`} = $memsd(decl*{decl <- `decl*`})) - -- if (table*{table <- `table*`} = $tablesd(decl*{decl <- `decl*`})) - -- if (func*{func <- `func*`} = $funcsd(decl*{decl <- `decl*`})) - -- if (data*{data <- `data*`} = $datasd(decl*{decl <- `decl*`})) - -- if (elem*{elem <- `elem*`} = $elemsd(decl*{decl <- `decl*`})) - -- if (lift(start?{start <- `start?`}) = $startsd(decl*{decl <- `decl*`})) - -- if (export*{export <- `export*`} = $exportsd(decl*{decl <- `decl*`})) - -- if $ordered(decl*{decl <- `decl*`}) + -- if (type*{type <- `type*`} = var_1) + -- if (import*{import <- `import*`} = var_2) + -- if (tag*{tag <- `tag*`} = var_3) + -- if (global*{global <- `global*`} = var_4) + -- if (mem*{mem <- `mem*`} = var_5) + -- if (table*{table <- `table*`} = var_6) + -- if (func*{func <- `func*`} = var_7) + -- if (data*{data <- `data*`} = var_8) + -- if (elem*{elem <- `elem*`} = var_9) + -- if (lift(start?{start <- `start?`}) = var_10) + -- if (export*{export <- `export*`} = var_11) + -- if var_12 + -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_12) + -- fun_exportsd: `%%`(decl*{decl <- `decl*`}, var_11) + -- fun_startsd: `%%`(decl*{decl <- `decl*`}, var_10) + -- fun_elemsd: `%%`(decl*{decl <- `decl*`}, var_9) + -- fun_datasd: `%%`(decl*{decl <- `decl*`}, var_8) + -- fun_funcsd: `%%`(decl*{decl <- `decl*`}, var_7) + -- fun_tablesd: `%%`(decl*{decl <- `decl*`}, var_6) + -- fun_memsd: `%%`(decl*{decl <- `decl*`}, var_5) + -- fun_globalsd: `%%`(decl*{decl <- `decl*`}, var_4) + -- fun_tagsd: `%%`(decl*{decl <- `decl*`}, var_3) + -- fun_importsd: `%%`(decl*{decl <- `decl*`}, var_2) + -- fun_typesd: `%%`(decl*{decl <- `decl*`}, var_1) + -- fun_concat_idctxt: `%%`(I*{I <- `I*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecldots_(I : I) : (decl, idctxt)* diff --git a/spectec/test-middlend/specification.exp/06-else.il b/spectec/test-middlend/specification.exp/14-alias-demut.il similarity index 52% rename from spectec/test-middlend/specification.exp/06-else.il rename to spectec/test-middlend/specification.exp/14-alias-demut.il index dbfa223b77..9e014ebc64 100644 --- a/spectec/test-middlend/specification.exp/06-else.il +++ b/spectec/test-middlend/specification.exp/14-alias-demut.il @@ -22,23 +22,31 @@ def $min(nat : nat, nat : nat) : nat ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.1-9.56 -def $sum(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:10.1-10.18 - def $sum([]) = 0 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:11.1-11.35 - def $sum{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n + $sum(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 +relation fun_sum: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_0: + `%%`([], 0) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#1*{n'#1 <- `n'*`}, (n + var_0)) + -- fun_sum: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.1-13.57 -def $prod(nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:14.1-14.19 - def $prod([]) = 1 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:15.1-15.37 - def $prod{n : nat, `n'*` : n*}([n] ++ n'*{n' <- `n'*`}) = (n * $prod(n'*{n' <- `n'*`})) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 +relation fun_prod: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_0: + `%%`([], 1) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_1{n : nat, `n'*` : n*, var_0 : nat}: + `%%`([n] ++ n'#2*{n'#2 <- `n'*`}, (n * var_0)) + -- fun_prod: `%%`(n'*{n' <- `n'*`}, var_0) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -58,7 +66,7 @@ def $concat_(syntax X, X**) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:15.1-15.34 def $concat_{syntax X}(syntax X, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:16.1-16.64 - def $concat_{syntax X, `w*` : X*, `w'**` : X**}(syntax X, [w*{w <- `w*`}] ++ w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) = w*{w <- `w*`} ++ $concat_(syntax X, w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) + def $concat_{syntax X, `w*` : X*, `w'**` : X**}(syntax X, [w#1*{w#1 <- `w*`}] ++ w'#1*{w'#1 <- `w'*#1`}*{`w'*#1` <- `w'**`}) = w*{w <- `w*`} ++ $concat_(syntax X, w'*{w' <- `w'*`}*{`w'*` <- `w'**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -69,7 +77,9 @@ def $concatn_(syntax X, X**, nat : nat) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:19.1-19.38 def $concatn_{syntax X, n : nat}(syntax X, [], n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 - def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w^n{w <- `w*`}] ++ w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + def $concatn_{syntax X, n : nat, `w*` : X*, `w'**` : X**}(syntax X, [w#2*{w#2 <- `w*`}] ++ w'#2*{w'#2 <- `w'*#2`}*{`w'*#2` <- `w'**`}, n) = w^n{w <- `w*`} ++ $concatn_(syntax X, w'^n{w' <- `w'*`}*{`w'*` <- `w'**`}, n) + -- if (n = |`w*`|) + -- (if (n = |`w'*#2`|))*{`w'*#2` <- `w'**`} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -77,7 +87,7 @@ def $concatopt_(syntax X, X?*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec def $concatopt_{syntax X}(syntax X, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec - def $concatopt_{syntax X, `w?` : X?, `w'?*` : X?*}(syntax X, [w?{w <- `w?`}] ++ w'?{w' <- `w'?`}*{`w'?` <- `w'?*`}) = lift(w?{w <- `w?`}) ++ $concat_(syntax X, lift(w'?{w' <- `w'?`})*{`w'?` <- `w'?*`}) + def $concatopt_{syntax X, `w?` : X?, `w'?*` : X?*}(syntax X, [w#3?{w#3 <- `w?`}] ++ w'#3?{w'#3 <- `w'?#1`}*{`w'?#1` <- `w'?*`}) = lift(w?{w <- `w?`}) ++ $concat_(syntax X, lift(w'?{w' <- `w'?`})*{`w'?` <- `w'?*`}) ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec def $inv_concat_(syntax X, X*) : X** @@ -93,7 +103,7 @@ def $disjoint_(syntax X, X*) : bool ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:36.1-36.37 def $disjoint_{syntax X}(syntax X, []) = true ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:37.1-37.68 - def $disjoint_{syntax X, w : X, `w'*` : X*}(syntax X, [w] ++ w'*{w' <- `w'*`}) = (~ (w <- w'*{w' <- `w'*`}) /\ $disjoint_(syntax X, w'*{w' <- `w'*`})) + def $disjoint_{syntax X, w : X, `w'*` : X*}(syntax X, [w] ++ w'#4*{w'#4 <- `w'*`}) = (~ (w <- w'*{w' <- `w'*`}) /\ $disjoint_(syntax X, w'*{w' <- `w'*`})) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -104,7 +114,7 @@ def $setminus1_(syntax X, X : X, X*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:44.1-44.38 def $setminus1_{syntax X, w : X}(syntax X, w, []) = [w] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:45.1-45.78 - def $setminus1_{syntax X, w : X, w_1 : X, `w'*` : X*}(syntax X, w, [w_1] ++ w'*{w' <- `w'*`}) = (if (w = w_1) then [] else $setminus1_(syntax X, w, w'*{w' <- `w'*`})) + def $setminus1_{syntax X, w : X, w_1 : X, `w'*` : X*}(syntax X, w, [w_1] ++ w'#5*{w'#5 <- `w'*`}) = (if (w = w_1) then [] else $setminus1_(syntax X, w, w'*{w' <- `w'*`})) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -113,9 +123,9 @@ rec { ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:39.1-39.56 def $setminus_(syntax X, X*, X*) : X* ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:42.1-42.40 - def $setminus_{syntax X, `w*` : X*}(syntax X, [], w*{w <- `w*`}) = [] + def $setminus_{syntax X, `w*` : X*}(syntax X, [], w#4*{w#4 <- `w*`}) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:43.1-43.90 - def $setminus_{syntax X, w_1 : X, `w'*` : X*, `w*` : X*}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}) = $setminus1_(syntax X, w_1, w*{w <- `w*`}) ++ $setminus_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}) + def $setminus_{syntax X, w_1 : X, `w'*` : X*, `w*` : X*}(syntax X, [w_1] ++ w'#6*{w'#6 <- `w'*`}, w#5*{w#5 <- `w*`}) = $setminus1_(syntax X, w_1, w*{w <- `w*`}) ++ $setminus_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -126,7 +136,7 @@ def $setproduct2_(syntax X, X : X, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:57.1-57.44 def $setproduct2_{syntax X, w_1 : X}(syntax X, w_1, []) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:58.1-58.90 - def $setproduct2_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, w_1, [w'*{w' <- `w'*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = [[w_1] ++ w'*{w' <- `w'*`}] ++ $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) + def $setproduct2_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, w_1, [w'#7*{w'#7 <- `w'*`}] ++ w#6*{w#6 <- `w*#1`}*{`w*#1` <- `w**`}) = [[w_1] ++ w'*{w' <- `w'*`}] ++ $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -135,9 +145,9 @@ rec { ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:50.1-50.47 def $setproduct1_(syntax X, X*, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:55.1-55.46 - def $setproduct1_{syntax X, `w**` : X**}(syntax X, [], w*{w <- `w*`}*{`w*` <- `w**`}) = [] + def $setproduct1_{syntax X, `w**` : X**}(syntax X, [], w#7*{w#7 <- `w*#2`}*{`w*#2` <- `w**`}) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:56.1-56.107 - def $setproduct1_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, [w_1] ++ w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) ++ $setproduct1_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) + def $setproduct1_{syntax X, w_1 : X, `w'*` : X*, `w**` : X**}(syntax X, [w_1] ++ w'#8*{w'#8 <- `w'*`}, w#8*{w#8 <- `w*#3`}*{`w*#3` <- `w**`}) = $setproduct2_(syntax X, w_1, w*{w <- `w*`}*{`w*` <- `w**`}) ++ $setproduct1_(syntax X, w'*{w' <- `w'*`}, w*{w <- `w*`}*{`w*` <- `w**`}) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -148,7 +158,7 @@ def $setproduct_(syntax X, X**) : X** ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:53.1-53.40 def $setproduct_{syntax X}(syntax X, []) = [[]] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:54.1-54.90 - def $setproduct_{syntax X, `w_1*` : X*, `w**` : X**}(syntax X, [w_1*{w_1 <- `w_1*`}] ++ w*{w <- `w*`}*{`w*` <- `w**`}) = $setproduct1_(syntax X, w_1*{w_1 <- `w_1*`}, $setproduct_(syntax X, w*{w <- `w*`}*{`w*` <- `w**`})) + def $setproduct_{syntax X, `w_1*` : X*, `w**` : X**}(syntax X, [w_1#1*{w_1#1 <- `w_1*`}] ++ w#9*{w#9 <- `w*#4`}*{`w*#4` <- `w**`}) = $setproduct1_(syntax X, w_1*{w_1 <- `w_1*`}, $setproduct_(syntax X, w*{w <- `w*`}*{`w*` <- `w**`})) } ;; ../../../../specification/wasm-3.0/1.0-syntax.profiles.spectec @@ -169,6 +179,11 @@ relation wf_bit: `%`(bit) syntax byte = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_byte_0(x : byte) : (nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_byte_0{v_num_0 : nat}(`%`_byte(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_byte: `%`(byte) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -180,6 +195,11 @@ relation wf_byte: `%`(byte) syntax uN = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_uN_0(x : uN) : (nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_uN_0{v_num_0 : nat}(`%`_uN(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_uN: `%%`(N, uN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -191,6 +211,11 @@ relation wf_uN: `%%`(N, uN) syntax sN = | `%`(i : int) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_sN_0(x : sN) : (int) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_sN_0{v_num_0 : int}(`%`_sN(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_sN: `%%`(N, sN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -314,19 +339,40 @@ syntax f64 = fN def $fzero(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fzero(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{N : nat, n : nat}(N, n) = POS_fN(NORM_fNmag(n, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{N : N, nat : nat, ret_val : fN}: + `%%%`(N, nat, ret_val) + -- if (ret_val = $fnat(N, nat)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{N : N, ret_val : fN}: + `%%`(N, ret_val) + -- if (ret_val = $fone(N)) + -- wf_fN: `%%`(N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(N : N) : nat @@ -344,10 +390,20 @@ syntax list{syntax X}(syntax X) = | `%`(`X*` : X*) -- if (|X*{X <- `X*`}| < (2 ^ 32)) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_list_0(syntax X, x : list(syntax X)) : (X*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_list_0{syntax X, v_X_list_0 : X*}(syntax X, `%`_list(v_X_list_0)) = (v_X_list_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax char = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_char_0(x : char) : (nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_char_0{v_num_0 : nat}(`%`_char(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_char: `%`(char) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -356,57 +412,86 @@ relation wf_char: `%`(char) -- if (((i >= 0) /\ (i <= 55295)) \/ ((i >= 57344) /\ (i <= 1114111))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -def $cont(byte : byte) : nat +relation fun_cont: `%%`(byte, nat) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - def $cont{b : byte}(b) = (((b!`%`_byte.0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat) - -- if ((128 < b!`%`_byte.0) /\ (b!`%`_byte.0 < 192)) + rule fun_cont_case_0{b : byte}: + `%%`(b, ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat)) + -- if ((128 < $proj_byte_0(b).0) /\ ($proj_byte_0(b).0 < 192)) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation fun_utf8: `%%`(char*, byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_0{`ch*` : char*, `var_0*` : byte**}: + `%%`(ch#1*{ch#1 <- `ch*`}, $concat_(syntax byte, var_0*{var_0 <- `var_0*`})) + -- (fun_utf8: `%%`([ch], var_0))*{var_0 <- `var_0*`, ch <- `ch*`} + -- if (|`var_0*`| = |`ch*`|) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_1{ch : char}: + `%%`([ch], [b]) + -- if ($proj_char_0(ch).0 < 128) + -- let{b : byte} b = `%`_byte($proj_char_0(ch).0) + -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_2{ch : char, b_1 : byte, b_2 : byte, var_0 : nat}: + `%%`([ch], [b_1 b_2]) + -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) + -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + var_0)) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_3{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3]) + -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) + -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * var_0)) + var_1)) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_4{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte, var_2 : nat, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3 b_4]) + -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) + -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * var_0)) + ((2 ^ 6) * var_1)) + var_2)) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) +} ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.1-91.25 -def $utf8(char*) : byte* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:52.1-52.44 - def $utf8{`ch*` : char*}(ch*{ch <- `ch*`}) = $concat_(syntax byte, $utf8([ch])*{ch <- `ch*`}) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:53.1-55.15 - def $utf8{ch : char}([ch]) = [b] - -- if (ch!`%`_char.0 < 128) - -- let{b : byte} b = `%`_byte(ch!`%`_char.0) - -- wf_byte: `%`(`%`_byte(ch!`%`_char.0)) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:56.1-58.46 - def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] - -- if ((128 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 2048)) - -- if (ch!`%`_char.0 = (((2 ^ 6) * (((b_1!`%`_byte.0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] - -- if (((2048 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 55296)) \/ ((57344 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 65536))) - -- if (ch!`%`_char.0 = ((((2 ^ 12) * (((b_1!`%`_byte.0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] - -- if ((65536 <= ch!`%`_char.0) /\ (ch!`%`_char.0 < 69632)) - -- if (ch!`%`_char.0 = (((((2 ^ 18) * (((b_1!`%`_byte.0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*, var_1 : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + -- fun_utf8: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax name = | `%`(`char*` : char*) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +def $proj_name_0(x : name) : (char*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + def $proj_name_0{v_char_list_0 : char*}(`%`_name(v_char_list_0)) = (v_char_list_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_name: `%`(name) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule name_case_0{`char*` : char*}: + rule name_case_0{`char*` : char*, var_0 : byte*}: `%`(`%`_name(`char*`)) -- (wf_char: `%`(char))*{char <- `char*`} - -- if (|$utf8(char*{char <- `char*`})| < (2 ^ 32)) + -- if (|var_0| < (2 ^ 32)) + -- fun_utf8: `%%`(char*{char <- `char*`}, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax idx = u32 @@ -485,66 +570,101 @@ relation wf_externidx: `%`(externidx) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.1-129.86 -def $funcsxx(externidx*) : typeidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:135.1-135.24 - def $funcsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:136.1-136.45 - def $funcsxx{x : uN, `xx*` : externidx*}([FUNC_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $funcsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:137.1-137.58 - def $funcsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $funcsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 +relation fun_funcsxx: `%%`(externidx*, typeidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_1{x : uN, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([FUNC_externidx(x)] ++ xx#1*{xx#1 <- `xx*`}, [x] ++ var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : typeidx*}: + `%%`([externidx] ++ xx#2*{xx#2 <- `xx*`}, var_0) + -- fun_funcsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.1-130.88 -def $globalsxx(externidx*) : globalidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:139.1-139.26 - def $globalsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:140.1-140.51 - def $globalsxx{x : uN, `xx*` : externidx*}([GLOBAL_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $globalsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:141.1-141.62 - def $globalsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $globalsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 +relation fun_globalsxx: `%%`(externidx*, globalidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_1{x : uN, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([GLOBAL_externidx(x)] ++ xx#3*{xx#3 <- `xx*`}, [x] ++ var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : globalidx*}: + `%%`([externidx] ++ xx#4*{xx#4 <- `xx*`}, var_0) + -- fun_globalsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.1-131.87 -def $tablesxx(externidx*) : tableidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:143.1-143.25 - def $tablesxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:144.1-144.48 - def $tablesxx{x : uN, `xx*` : externidx*}([TABLE_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tablesxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:145.1-145.60 - def $tablesxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tablesxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 +relation fun_tablesxx: `%%`(externidx*, tableidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_1{x : uN, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([TABLE_externidx(x)] ++ xx#5*{xx#5 <- `xx*`}, [x] ++ var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tableidx*}: + `%%`([externidx] ++ xx#6*{xx#6 <- `xx*`}, var_0) + -- fun_tablesxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.1-132.85 -def $memsxx(externidx*) : memidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:147.1-147.23 - def $memsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:148.1-148.42 - def $memsxx{x : uN, `xx*` : externidx*}([MEM_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $memsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:149.1-149.56 - def $memsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $memsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 +relation fun_memsxx: `%%`(externidx*, memidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_1{x : uN, `xx*` : externidx*, var_0 : memidx*}: + `%%`([MEM_externidx(x)] ++ xx#7*{xx#7 <- `xx*`}, [x] ++ var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : memidx*}: + `%%`([externidx] ++ xx#8*{xx#8 <- `xx*`}, var_0) + -- fun_memsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.1-133.85 -def $tagsxx(externidx*) : tagidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:151.1-151.23 - def $tagsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:152.1-152.42 - def $tagsxx{x : uN, `xx*` : externidx*}([TAG_externidx(x)] ++ xx*{xx <- `xx*`}) = [x] ++ $tagsxx(xx*{xx <- `xx*`}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:153.1-153.56 - def $tagsxx{externidx : externidx, `xx*` : externidx*}([externidx] ++ xx*{xx <- `xx*`}) = $tagsxx(xx*{xx <- `xx*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 +relation fun_tagsxx: `%%`(externidx*, tagidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_1{x : uN, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([TAG_externidx(x)] ++ xx#9*{xx#9 <- `xx*`}, [x] ++ var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_2{externidx : externidx, `xx*` : externidx*, var_0 : tagidx*}: + `%%`([externidx] ++ xx#10*{xx#10 <- `xx*`}, var_0) + -- fun_tagsxx: `%%`(xx*{xx <- `xx*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -582,81 +702,186 @@ relation wf_free: `%`(free) def $free_opt(free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{free : free}(?(free)) = free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation fun_free_list: `%%`(free*, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_0: + `%%`([], {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_1{free : free, `free'*` : free*, var_0 : free}: + `%%`([free] ++ free'#1*{free'#1 <- `free'*`}, free +++ var_0) + -- fun_free_list: `%%`(free'*{free' <- `free'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.1-173.29 -def $free_list(free*) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 - def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 - def $free_list{free : free, `free'*` : free*}([free] ++ free'*{free' <- `free'*`}) = free +++ $free_list(free'*{free' <- `free'*`}) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_list: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{typeidx : uN}(typeidx) = {TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{typeidx : typeidx, ret_val : free}: + `%%`(typeidx, ret_val) + -- wf_uN: `%%`(32, typeidx) + -- if (ret_val = $free_typeidx(typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{funcidx : uN}(funcidx) = {TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{funcidx : funcidx, ret_val : free}: + `%%`(funcidx, ret_val) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $free_funcidx(funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{globalidx : uN}(globalidx) = {TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{globalidx : globalidx, ret_val : free}: + `%%`(globalidx, ret_val) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $free_globalidx(globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{tableidx : uN}(tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{tableidx : tableidx, ret_val : free}: + `%%`(tableidx, ret_val) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $free_tableidx(tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{memidx : uN}(memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{memidx : memidx, ret_val : free}: + `%%`(memidx, ret_val) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $free_memidx(memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{elemidx : uN}(elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{elemidx : elemidx, ret_val : free}: + `%%`(elemidx, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- if (ret_val = $free_elemidx(elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{dataidx : uN}(dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{dataidx : dataidx, ret_val : free}: + `%%`(dataidx, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $free_dataidx(dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{localidx : uN}(localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{localidx : localidx, ret_val : free}: + `%%`(localidx, ret_val) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $free_localidx(localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{labelidx : uN}(labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{labelidx : labelidx, ret_val : free}: + `%%`(labelidx, ret_val) + -- wf_uN: `%%`(32, labelidx) + -- if (ret_val = $free_labelidx(labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{tagidx : uN}(tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{tagidx : tagidx, ret_val : free}: + `%%`(tagidx, ret_val) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $free_tagidx(tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(externidx : externidx) : free @@ -671,6 +896,15 @@ def $free_externidx(externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{externidx : externidx, ret_val : free}: + `%%`(externidx, ret_val) + -- wf_externidx: `%`(externidx) + -- if (ret_val = $free_externidx(externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -687,6 +921,10 @@ syntax numtype = | F32 | F64 +def $numtype_addrtype(addrtype) : numtype + def $numtype_addrtype(I32_addrtype) = I32_numtype + def $numtype_addrtype(I64_addrtype) = I64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax vectype = | V128 @@ -699,6 +937,12 @@ syntax consttype = | F64 | V128 +def $consttype_numtype(numtype) : consttype + def $consttype_numtype(I32_numtype) = I32_consttype + def $consttype_numtype(I64_numtype) = I64_consttype + def $consttype_numtype(F32_numtype) = F32_consttype + def $consttype_numtype(F64_numtype) = F64_consttype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax absheaptype = | ANY @@ -773,9 +1017,6 @@ syntax storagetype = | I8 | I16 -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:102.1-103.16 -syntax resulttype = list(syntax valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.1-112.61 syntax fieldtype = | `%%`(`mut?` : mut?, storagetype : storagetype) @@ -784,7 +1025,7 @@ syntax fieldtype = syntax comptype = | STRUCT(list(syntax fieldtype)) | ARRAY(fieldtype : fieldtype) - | `FUNC%->%`(resulttype : resulttype, resulttype : resulttype) + | `FUNC%->%`(resulttype : list(syntax valtype), resulttype : list(syntax valtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:119.1-120.33 syntax subtype = @@ -795,6 +1036,67 @@ syntax rectype = | REC(list(syntax subtype)) } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +syntax resulttype = list(syntax valtype) + +def $heaptype_absheaptype(absheaptype) : heaptype + def $heaptype_absheaptype(ANY_absheaptype) = ANY_heaptype + def $heaptype_absheaptype(EQ_absheaptype) = EQ_heaptype + def $heaptype_absheaptype(I31_absheaptype) = I31_heaptype + def $heaptype_absheaptype(STRUCT_absheaptype) = STRUCT_heaptype + def $heaptype_absheaptype(ARRAY_absheaptype) = ARRAY_heaptype + def $heaptype_absheaptype(NONE_absheaptype) = NONE_heaptype + def $heaptype_absheaptype(FUNC_absheaptype) = FUNC_heaptype + def $heaptype_absheaptype(NOFUNC_absheaptype) = NOFUNC_heaptype + def $heaptype_absheaptype(EXN_absheaptype) = EXN_heaptype + def $heaptype_absheaptype(NOEXN_absheaptype) = NOEXN_heaptype + def $heaptype_absheaptype(EXTERN_absheaptype) = EXTERN_heaptype + def $heaptype_absheaptype(NOEXTERN_absheaptype) = NOEXTERN_heaptype + def $heaptype_absheaptype(BOT_absheaptype) = BOT_heaptype + +def $valtype_addrtype(addrtype) : valtype + def $valtype_addrtype(I32_addrtype) = I32_valtype + def $valtype_addrtype(I64_addrtype) = I64_valtype + +def $storagetype_consttype(consttype) : storagetype + def $storagetype_consttype(I32_consttype) = I32_storagetype + def $storagetype_consttype(I64_consttype) = I64_storagetype + def $storagetype_consttype(F32_consttype) = F32_storagetype + def $storagetype_consttype(F64_consttype) = F64_storagetype + def $storagetype_consttype(V128_consttype) = V128_storagetype + +def $storagetype_numtype(numtype) : storagetype + def $storagetype_numtype(I32_numtype) = I32_storagetype + def $storagetype_numtype(I64_numtype) = I64_storagetype + def $storagetype_numtype(F32_numtype) = F32_storagetype + def $storagetype_numtype(F64_numtype) = F64_storagetype + +def $valtype_numtype(numtype) : valtype + def $valtype_numtype(I32_numtype) = I32_valtype + def $valtype_numtype(I64_numtype) = I64_valtype + def $valtype_numtype(F32_numtype) = F32_valtype + def $valtype_numtype(F64_numtype) = F64_valtype + +def $heaptype_typeuse(typeuse) : heaptype + def $heaptype_typeuse{x0 : typeidx}(_IDX_typeuse(x0)) = _IDX_heaptype(x0) + def $heaptype_typeuse{x0 : rectype, x1 : n}(_DEF_typeuse(x0, x1)) = _DEF_heaptype(x0, x1) + def $heaptype_typeuse{x0 : n}(REC_typeuse(x0)) = REC_heaptype(x0) + +def $storagetype_valtype(valtype) : storagetype + def $storagetype_valtype(I32_valtype) = I32_storagetype + def $storagetype_valtype(I64_valtype) = I64_storagetype + def $storagetype_valtype(F32_valtype) = F32_storagetype + def $storagetype_valtype(F64_valtype) = F64_storagetype + def $storagetype_valtype(V128_valtype) = V128_storagetype + def $storagetype_valtype{x0 : null?, x1 : heaptype}(REF_valtype(x0, x1)) = REF_storagetype(x0, x1) + def $storagetype_valtype(BOT_valtype) = BOT_storagetype + +def $storagetype_vectype(vectype) : storagetype + def $storagetype_vectype(V128_vectype) = V128_storagetype + +def $valtype_vectype(vectype) : valtype + def $valtype_vectype(V128_vectype) = V128_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { @@ -985,11 +1287,21 @@ relation wf_subtype: `%`(subtype) syntax deftype = | _DEF(rectype : rectype, n : n) +def $heaptype_deftype(deftype) : heaptype + def $heaptype_deftype{x0 : rectype, x1 : n}(_DEF_deftype(x0, x1)) = _DEF_heaptype(x0, x1) + +def $typeuse_deftype(deftype) : typeuse + def $typeuse_deftype{x0 : rectype, x1 : n}(_DEF_deftype(x0, x1)) = _DEF_typeuse(x0, x1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax typevar = | _IDX(typeidx : typeidx) | REC(n : n) +def $typeuse_typevar(typevar) : typeuse + def $typeuse_typevar{x0 : typeidx}(_IDX_typevar(x0)) = _IDX_typeuse(x0) + def $typeuse_typevar{x0 : n}(REC_typevar(x0)) = REC_typeuse(x0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_typevar: `%`(typevar) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1005,6 +1317,12 @@ relation wf_typevar: `%`(typevar) syntax reftype = | REF(`null?` : null?, heaptype : heaptype) +def $storagetype_reftype(reftype) : storagetype + def $storagetype_reftype{x0 : null?, x1 : heaptype}(REF_reftype(x0, x1)) = REF_storagetype(x0, x1) + +def $valtype_reftype(reftype) : valtype + def $valtype_reftype{x0 : null?, x1 : heaptype}(REF_reftype(x0, x1)) = REF_valtype(x0, x1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_reftype: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1020,6 +1338,10 @@ syntax Fnn = | F32 | F64 +def $numtype_Fnn(Fnn) : numtype + def $numtype_Fnn(F32_Fnn) = F32_numtype + def $numtype_Fnn(F64_Fnn) = F64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Vnn = vectype @@ -1031,83 +1353,178 @@ syntax Cnn = | F64 | V128 +def $storagetype_Cnn(Cnn) : storagetype + def $storagetype_Cnn(I32_Cnn) = I32_storagetype + def $storagetype_Cnn(I64_Cnn) = I64_storagetype + def $storagetype_Cnn(F32_Cnn) = F32_storagetype + def $storagetype_Cnn(F64_Cnn) = F64_storagetype + def $storagetype_Cnn(V128_Cnn) = V128_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = | I8 | I16 +def $storagetype_packtype(packtype) : storagetype + def $storagetype_packtype(I8_packtype) = I8_storagetype + def $storagetype_packtype(I16_packtype) = I16_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax lanetype = | I32 @@ -1117,6 +1534,24 @@ syntax lanetype = | I8 | I16 +def $lanetype_Fnn(Fnn) : lanetype + def $lanetype_Fnn(F32_Fnn) = F32_lanetype + def $lanetype_Fnn(F64_Fnn) = F64_lanetype + +def $lanetype_addrtype(addrtype) : lanetype + def $lanetype_addrtype(I32_addrtype) = I32_lanetype + def $lanetype_addrtype(I64_addrtype) = I64_lanetype + +def $lanetype_numtype(numtype) : lanetype + def $lanetype_numtype(I32_numtype) = I32_lanetype + def $lanetype_numtype(I64_numtype) = I64_lanetype + def $lanetype_numtype(F32_numtype) = F32_lanetype + def $lanetype_numtype(F64_numtype) = F64_lanetype + +def $lanetype_packtype(packtype) : lanetype + def $lanetype_packtype(I8_packtype) = I8_lanetype + def $lanetype_packtype(I16_packtype) = I16_lanetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Pnn = packtype @@ -1127,6 +1562,16 @@ syntax Jnn = | I8 | I16 +def $lanetype_Jnn(Jnn) : lanetype + def $lanetype_Jnn(I32_Jnn) = I32_lanetype + def $lanetype_Jnn(I64_Jnn) = I64_lanetype + def $lanetype_Jnn(I8_Jnn) = I8_lanetype + def $lanetype_Jnn(I16_Jnn) = I16_lanetype + +def $Jnn_addrtype(addrtype) : Jnn + def $Jnn_addrtype(I32_addrtype) = I32_Jnn + def $Jnn_addrtype(I64_addrtype) = I64_Jnn + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax Lnn = lanetype @@ -1140,7 +1585,6 @@ relation wf_limits: `%`(limits) rule limits_case_0{u64 : u64, `u64?` : u64?}: `%`(`[%..%]`_limits(u64, `u64?`)) -- wf_uN: `%%`(64, u64) - -- (wf_uN: `%%`(64, u64))?{u64 <- `u64?`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax tagtype = typeuse @@ -1290,35 +1734,51 @@ def $psize(packtype : packtype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lsize(lanetype : lanetype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{numtype : numtype}((numtype : numtype <: lanetype)) = $size(numtype) + def $lsize(I32_lanetype) = $size(I32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(I64_lanetype) = $size(I64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(F32_lanetype) = $size(F32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(F64_lanetype) = $size(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lsize{packtype : packtype}((packtype : packtype <: lanetype)) = $psize(packtype) + def $lsize(I8_lanetype) = $psize(I8_packtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $zsize(storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{numtype : numtype}((numtype : numtype <: storagetype)) = ?($size(numtype)) + def $zsize(I32_storagetype) = ?($size(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(I64_storagetype) = ?($size(I64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(F32_storagetype) = ?($size(F32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{vectype : vectype}((vectype : vectype <: storagetype)) = ?($vsize(vectype)) + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{packtype : packtype}((packtype : packtype <: storagetype)) = ?($psize(packtype)) + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $zsize(I16_storagetype) = ?($psize(I16_packtype)) def $zsize{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $isize(Inn : Inn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $isize{Inn : addrtype}(Inn) = $size((Inn : addrtype <: numtype)) + def $isize{Inn : addrtype}(Inn) = $size($numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $jsize(Jnn : Jnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsize{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) + def $jsize{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $fsize(Fnn : Fnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $fsize{Fnn : Fnn}(Fnn) = $size((Fnn : Fnn <: numtype)) + def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_isize(nat : nat) : Inn? @@ -1336,7 +1796,7 @@ def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize{n : nat}(n) = (iter_val#1 : addrtype <: Jnn)?{iter_val#1 <- $inv_isize(n)} + def $inv_jsize{n : nat}(n) = $Jnn_addrtype(iter_val#1)?{iter_val#1 <- $inv_isize(n)} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_fsize(nat : nat) : Fnn? @@ -1390,7 +1850,7 @@ def $lsizenn2(lanetype : lanetype) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $jsizenn(Jnn : Jnn) : nat ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $jsizenn{Jnn : Jnn}(Jnn) = $lsize((Jnn : Jnn <: lanetype)) + def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_jsizenn(nat : nat) : Jnn? @@ -1400,443 +1860,1091 @@ def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{numtype : numtype}((numtype : numtype <: lanetype)) = numtype + def $lunpack(I32_lanetype) = I32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(I64_lanetype) = I64_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(F32_lanetype) = F32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(F64_lanetype) = F64_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $lunpack{packtype : packtype}((packtype : packtype <: lanetype)) = I32_numtype + def $lunpack(I8_lanetype) = I32_numtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $lunpack(I16_lanetype) = I32_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(storagetype : storagetype) : valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype + def $unpack(BOT_storagetype) = BOT_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack{`null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype)) = REF_valtype(`null?`, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(V128_storagetype) = V128_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(F64_storagetype) = F64_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{packtype : packtype}((packtype : packtype <: storagetype)) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + def $unpack(F32_storagetype) = F32_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I64_storagetype) = I64_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I32_storagetype) = I32_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I8_storagetype) = I32_valtype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $unpack(I16_storagetype) = I32_valtype + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{storagetype : storagetype, ret_val : valtype}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = $unpack(storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{numtype : numtype}((numtype : numtype <: storagetype)) = ?(numtype) + def $nunpack(I32_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_numtype) + def $nunpack(I64_storagetype) = ?(I64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(F32_storagetype) = ?(F32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(F64_storagetype) = ?(F64_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(I8_storagetype) = ?(I32_numtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $nunpack(I16_storagetype) = ?(I32_numtype) def $nunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $vunpack(storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack{vectype : vectype}((vectype : vectype <: storagetype)) = ?(vectype) + def $vunpack(V128_storagetype) = ?(V128_vectype) def $vunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $cunpack(storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{consttype : consttype}((consttype : consttype <: storagetype)) = ?(consttype) + def $cunpack(I32_storagetype) = ?(I32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I64_storagetype) = ?(I64_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F32_storagetype) = ?(F32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F64_storagetype) = ?(F64_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(V128_storagetype) = ?(V128_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{packtype : packtype}((packtype : packtype <: storagetype)) = ?(I32_consttype) + def $cunpack(I8_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack{lanetype : lanetype}((lanetype : lanetype <: storagetype)) = ?(($lunpack(lanetype) : numtype <: consttype)) + def $cunpack(I16_storagetype) = ?(I32_consttype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $cunpack(I16_storagetype) = ?($consttype_numtype($lunpack(I16_lanetype))) def $cunpack{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $minat{at_1 : addrtype, at_2 : addrtype}(at_1, at_2) = (if ($size((at_1 : addrtype <: numtype)) <= $size((at_2 : addrtype <: numtype))) then at_1 else at_2) + def $minat{at_1 : addrtype, at_2 : addrtype}(at_1, at_2) = (if ($size($numtype_addrtype(at_1)) <= $size($numtype_addrtype(at_2))) then at_1 else at_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt(reftype : reftype, reftype : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) + def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#1?{null_1#1 <- `null_1?`}, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1#2?{null_1#2 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(reftype : reftype, reftype_0 : reftype, ret_val : reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $diffrt{`null_1?` : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1?{null_1 <- `null_1?`}, ht_1)) + rule diffrt_is_wf_0{reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(reftype, reftype_0, ret_val) + -- wf_reftype: `%`(reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $as_deftype{dt : deftype}((dt : deftype <: typeuse)) = ?(dt) + def $as_deftype{rectype : rectype, n : n}(_DEF_typeuse(rectype, n)) = ?(_DEF_deftype(rectype, n)) def $as_deftype{x0 : typeuse}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.1-308.87 -def $tagsxt(externtype*) : tagtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:314.1-314.23 - def $tagsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:315.1-315.44 - def $tagsxt{jt : typeuse, `xt*` : externtype*}([TAG_externtype(jt)] ++ xt*{xt <- `xt*`}) = [jt] ++ $tagsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:316.1-316.57 - def $tagsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tagsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 +relation fun_tagsxt: `%%`(externtype*, tagtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_1{jt : typeuse, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([TAG_externtype(jt)] ++ xt#1*{xt#1 <- `xt*`}, [jt] ++ var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tagtype*}: + `%%`([externtype] ++ xt#2*{xt#2 <- `xt*`}, var_0) + -- fun_tagsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.1-309.90 -def $globalsxt(externtype*) : globaltype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:318.1-318.26 - def $globalsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:319.1-319.53 - def $globalsxt{gt : globaltype, `xt*` : externtype*}([GLOBAL_externtype(gt)] ++ xt*{xt <- `xt*`}) = [gt] ++ $globalsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:320.1-320.63 - def $globalsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $globalsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation fun_globalsxt: `%%`(externtype*, globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_1{gt : globaltype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([GLOBAL_externtype(gt)] ++ xt#3*{xt#3 <- `xt*`}, [gt] ++ var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : globaltype*}: + `%%`([externtype] ++ xt#4*{xt#4 <- `xt*`}, var_0) + -- fun_globalsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 -def $memsxt(externtype*) : memtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 - def $memsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:323.1-323.44 - def $memsxt{mt : memtype, `xt*` : externtype*}([MEM_externtype(mt)] ++ xt*{xt <- `xt*`}) = [mt] ++ $memsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:324.1-324.57 - def $memsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $memsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*, var_1 : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 -def $tablesxt(externtype*) : tabletype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 - def $tablesxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:327.1-327.50 - def $tablesxt{tt : tabletype, `xt*` : externtype*}([TABLE_externtype(tt)] ++ xt*{xt <- `xt*`}) = [tt] ++ $tablesxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:328.1-328.61 - def $tablesxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $tablesxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation fun_memsxt: `%%`(externtype*, memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_1{mt : memtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([MEM_externtype(mt)] ++ xt#5*{xt#5 <- `xt*`}, [mt] ++ var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : memtype*}: + `%%`([externtype] ++ xt#6*{xt#6 <- `xt*`}, var_0) + -- fun_memsxt: `%%`(xt*{xt <- `xt*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 -def $funcsxt(externtype*) : deftype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 - def $funcsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:331.1-331.47 - def $funcsxt{dt : deftype, `xt*` : externtype*}([FUNC_externtype((dt : deftype <: typeuse))] ++ xt*{xt <- `xt*`}) = [dt] ++ $funcsxt(xt*{xt <- `xt*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:332.1-332.59 - def $funcsxt{externtype : externtype, `xt*` : externtype*}([externtype] ++ xt*{xt <- `xt*`}) = $funcsxt(xt*{xt <- `xt*`}) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*, var_1 : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.1-337.126 -def $subst_typevar(typevar : typevar, typevar*, typeuse*) : typeuse? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:365.1-365.38 - def $subst_typevar{tv : typevar}(tv, [], []) = ?((tv : typevar <: typeuse)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:366.1-366.95 - def $subst_typevar{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*}(tv, [tv_1] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`}) = (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- $subst_typevar(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})} - def $subst_typevar{x0 : typevar, x1 : typevar*, x2 : typeuse*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation fun_tablesxt: `%%`(externtype*, tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_1{tt : tabletype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([TABLE_externtype(tt)] ++ xt#7*{xt#7 <- `xt*`}, [tt] ++ var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : tabletype*}: + `%%`([externtype] ++ xt#8*{xt#8 <- `xt*`}, var_0) + -- fun_tablesxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*, var_1 : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesxt: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 +relation fun_funcsxt: `%%`(externtype*, deftype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_1{rectype : rectype, n : n, `xt*` : externtype*, var_0 : deftype*}: + `%%`([FUNC_externtype(_DEF_typeuse(rectype, n))] ++ xt#9*{xt#9 <- `xt*`}, [_DEF_deftype(rectype, n)] ++ var_0) + -- fun_funcsxt: `%%`(xt#10*{xt#10 <- `xt*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_2{externtype : externtype, `xt*` : externtype*, var_0 : deftype*}: + `%%`([externtype] ++ xt#11*{xt#11 <- `xt*`}, var_0) + -- fun_funcsxt: `%%`(xt*{xt <- `xt*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(typevar, typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%`(tv, [], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation fun_subst_typevar: `%%%%`(typevar, typevar*, typeuse*, typeuse?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%%`(tv, [], [], ?($typeuse_typevar(tv))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, `tv'*` : typevar*, tu_1 : typeuse, `tu'*` : typeuse*, var_0 : typeuse?}: + `%%%%`(tv, [tv_1] ++ tv'#1*{tv'#1 <- `tv'*`}, [tu_1] ++ tu'#1*{tu'#1 <- `tu'*`}, (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- var_0}) + -- fun_subst_typevar: `%%%%`(tv, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_2{x0 : typevar, x1 : typevar*, x2 : typeuse*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse?}: + `%%%%`(typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typevar: `%%%%`(typevar, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(typevar*, typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:403.1-403.63 - def $minus_recs{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([REC_typevar(n)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + def $minus_recs{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) = $minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 - def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_typevar: `%`(_IDX_typevar(x)) + def $minus_recs{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*}([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#2*{tv'#2 <- `tv'*`}, tu'#2*{tu'#2 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`})) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- if ($minus_recs(var_0, var_1) =/= ?()) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(packtype : packtype, typevar*, typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_packtype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = pt + def $subst_packtype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}(pt, tv#4*{tv#4 <- `tv*`}, tu#4*{tu#4 <- `tu*`}) = pt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_numtype(numtype : numtype, typevar*, typeuse*) : numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_numtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = nt + def $subst_numtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}(nt, tv#5*{tv#5 <- `tv*`}, tu#5*{tu#5 <- `tu*`}) = nt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_vectype(vectype : vectype, typevar*, typeuse*) : vectype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_vectype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = vt + def $subst_vectype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}(vt, tv#6*{tv#6 <- `tv*`}, tu#6*{tu#6 <- `tu*`}) = vt ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.1-338.112 -def $subst_typeuse(typeuse : typeuse, typevar*, typeuse*) : typeuse - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = !($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:370.1-370.64 - def $subst_typeuse{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: typeuse), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.1-343.112 -def $subst_heaptype(heaptype : heaptype, typevar*, typeuse*) : heaptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{tv' : typevar, `tv*` : typevar*, `tu*` : typeuse*}((tv' : typevar <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = (!($subst_typevar(tv', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) : typeuse <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:377.1-377.65 - def $subst_heaptype{dt : deftype, `tv*` : typevar*, `tu*` : typeuse*}((dt : deftype <: heaptype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_deftype(dt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : deftype <: heaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:378.1-378.53 - def $subst_heaptype{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ht - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.1-344.112 -def $subst_reftype(reftype : reftype, typevar*, typeuse*) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 - def $subst_reftype{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}(REF_reftype(null?{null <- `null?`}, ht), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_reftype: `%`(REF_reftype(null?{null <- `null?`}, $subst_heaptype(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 -def $subst_valtype(valtype : valtype, typevar*, typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{nt : numtype, `tv*` : typevar*, `tu*` : typeuse*}((nt : numtype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_numtype(nt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : numtype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{vt : vectype, `tv*` : typevar*, `tu*` : typeuse*}((vt : vectype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_vectype(vt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : vectype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}((rt : reftype <: valtype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : reftype <: valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{`tv*` : typevar*, `tu*` : typeuse*}(BOT_valtype, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation fun_subst_typeuse: `%%%%`(typeuse, typevar*, typeuse*, typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_typeuse(n), tv#7*{tv#7 <- `tv*`}, tu#7*{tu#7 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#8*{tv#8 <- `tv*`}, tu#8*{tu#8 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_typeuse(typeidx), tv#9*{tv#9 <- `tv*`}, tu#9*{tu#9 <- `tu*`}, !(var_0)) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#10*{tv#10 <- `tv*`}, tu#10*{tu#10 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_typeuse(rectype, n), tv#11*{tv#11 <- `tv*`}, tu#11*{tu#11 <- `tu*`}, $typeuse_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#12*{tv#12 <- `tv*`}, tu#12*{tu#12 <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation fun_subst_heaptype: `%%%%`(heaptype, typevar*, typeuse*, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_0{n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_heaptype(n), tv#13*{tv#13 <- `tv*`}, tu#13*{tu#13 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(REC_typevar(n), tv#14*{tv#14 <- `tv*`}, tu#14*{tu#14 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_1{typeidx : typeidx, `tv*` : typevar*, `tu*` : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_heaptype(typeidx), tv#15*{tv#15 <- `tv*`}, tu#15*{tu#15 <- `tu*`}, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(typeidx), tv#16*{tv#16 <- `tv*`}, tu#16*{tu#16 <- `tu*`}, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_2{rectype : rectype, n : n, `tv*` : typevar*, `tu*` : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_heaptype(rectype, n), tv#17*{tv#17 <- `tv*`}, tu#17*{tu#17 <- `tu*`}, $heaptype_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(rectype, n), tv#18*{tv#18 <- `tv*`}, tu#18*{tu#18 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_3{ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(ht, tv#19*{tv#19 <- `tv*`}, tu#19*{tu#19 <- `tu*`}, ht) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation fun_subst_reftype: `%%%%`(reftype, typevar*, typeuse*, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule fun_subst_reftype_case_0{`null?` : null?, ht : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : heaptype}: + `%%%%`(REF_reftype(null#1?{null#1 <- `null?`}, ht), tv#20*{tv#20 <- `tv*`}, tu#20*{tu#20 <- `tu*`}, REF_reftype(null?{null <- `null?`}, var_0)) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_0{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I32_valtype, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, $valtype_numtype($subst_numtype(I32_numtype, tv#22*{tv#22 <- `tv*`}, tu#22*{tu#22 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_1{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I64_valtype, tv#23*{tv#23 <- `tv*`}, tu#23*{tu#23 <- `tu*`}, $valtype_numtype($subst_numtype(I64_numtype, tv#24*{tv#24 <- `tv*`}, tu#24*{tu#24 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_2{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F32_valtype, tv#25*{tv#25 <- `tv*`}, tu#25*{tu#25 <- `tu*`}, $valtype_numtype($subst_numtype(F32_numtype, tv#26*{tv#26 <- `tv*`}, tu#26*{tu#26 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_3{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(F64_valtype, tv#27*{tv#27 <- `tv*`}, tu#27*{tu#27 <- `tu*`}, $valtype_numtype($subst_numtype(F64_numtype, tv#28*{tv#28 <- `tv*`}, tu#28*{tu#28 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_4{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(V128_valtype, tv#29*{tv#29 <- `tv*`}, tu#29*{tu#29 <- `tu*`}, $valtype_vectype($subst_vectype(V128_vectype, tv#30*{tv#30 <- `tv*`}, tu#30*{tu#30 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_5{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(REF_valtype(`null?`, heaptype), tv#31*{tv#31 <- `tv*`}, tu#31*{tu#31 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_6{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(BOT_valtype, tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `tu*`}, BOT_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation fun_subst_storagetype: `%%%%`(storagetype, typevar*, typeuse*, storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_0{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(BOT_storagetype, tv#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_1{`null?` : null?, heaptype : heaptype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(REF_storagetype(`null?`, heaptype), tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_2{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(V128_storagetype, tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_3{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F64_storagetype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_4{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(F32_storagetype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_5{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I64_storagetype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_6{`tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(I32_storagetype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_7{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I8_storagetype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `tu*`}, $storagetype_packtype($subst_packtype(I8_packtype, tv#49*{tv#49 <- `tv*`}, tu#49*{tu#49 <- `tu*`}))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_8{`tv*` : typevar*, `tu*` : typeuse*}: + `%%%%`(I16_storagetype, tv#50*{tv#50 <- `tv*`}, tu#50*{tu#50 <- `tu*`}, $storagetype_packtype($subst_packtype(I16_packtype, tv#51*{tv#51 <- `tv*`}, tu#51*{tu#51 <- `tu*`}))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation fun_subst_fieldtype: `%%%%`(fieldtype, typevar*, typeuse*, fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule fun_subst_fieldtype_case_0{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#52*{tv#52 <- `tv*`}, tu#52*{tu#52 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_0{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + -- if (|`var_0*`| = |`ft*`|) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_1{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_2{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_1*` : valtype*, `var_0*` : valtype*}: + `%%%%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#1*{t_1#1 <- `t_1*`}), `%`_resulttype(t_2#1*{t_2#1 <- `t_2*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} + -- if (|`var_1*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} + -- if (|`var_0*`| = |`t_1*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation fun_subst_subtype: `%%%%`(subtype, typevar*, typeuse*, subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule fun_subst_subtype_case_0{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#3*{tu'#3 <- `tu'*`}, ct), tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) + -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} + -- if (|`var_0*`| = |`tu'*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 +relation fun_subst_rectype: `%%%%`(rectype, typevar*, typeuse*, rectype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 + rule fun_subst_rectype_case_0{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'#3*{tv'#3 <- `tv'*`}, tu'#4*{tu'#4 <- `tu'*`}) = !($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`})) + -- if ($minus_recs(tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}) =/= ?()) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} + -- if (|`var_0*`| = |`st*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 +relation fun_subst_deftype: `%%%%`(deftype, typevar*, typeuse*, deftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 + rule fun_subst_deftype_case_0{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*, var_0 : rectype}: + `%%%%`(_DEF_deftype(qt, i), tv#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, _DEF_deftype(var_0, i)) + -- fun_subst_rectype: `%%%%`(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 -def $subst_storagetype(storagetype : storagetype, typevar*, typeuse*) : storagetype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{t : valtype, `tv*` : typevar*, `tu*` : typeuse*}((t : valtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : valtype <: storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{pt : packtype, `tv*` : typevar*, `tu*` : typeuse*}((pt : packtype <: storagetype), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ($subst_packtype(pt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) : packtype <: storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 -def $subst_fieldtype(fieldtype : fieldtype, typevar*, typeuse*) : fieldtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{`mut?` : mut?, zt : storagetype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_fieldtype(mut?{mut <- `mut?`}, zt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, $subst_storagetype(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 -def $subst_comptype(comptype : comptype, typevar*, typeuse*) : comptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{`ft*` : fieldtype*, `tv*` : typevar*, `tu*` : typeuse*}(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{ft <- `ft*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, `tv*` : typevar*, `tu*` : typeuse*}(ARRAY_comptype(ft), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{`t_1*` : valtype*, `t_2*` : valtype*, `tv*` : typevar*, `tu*` : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_1 <- `t_1*`}), `%`_resulttype($subst_valtype(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{t_2 <- `t_2*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 -def $subst_subtype(subtype : subtype, typevar*, typeuse*) : subtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{`final?` : final?, `tu'*` : typeuse*, ct : comptype, `tv*` : typevar*, `tu*` : typeuse*}(SUB_subtype(final?{final <- `final?`}, tu'*{tu' <- `tu'*`}, ct), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{tu' <- `tu'*`}, $subst_comptype(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 -def $subst_rectype(rectype : rectype, typevar*, typeuse*) : rectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{`st*` : subtype*, `tv*` : typevar*, `tu*` : typeuse*}(REC_rectype(`%`_list(st*{st <- `st*`})), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = REC_rectype(`%`_list($subst_subtype(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`})*{st <- `st*`})) - -- let{`tv'*` : typevar*, `tu'*` : typeuse*} (tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 -def $subst_deftype(deftype : deftype, typevar*, typeuse*) : deftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, `tv*` : typevar*, `tu*` : typeuse*}(_DEF_deftype(qt, i), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = _DEF_deftype($subst_rectype(qt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}), i) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse}: + `%%%%`(typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typeuse: `%%%%`(typeuse, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype, var_2 : heaptype}: + `%%%%`(heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_heaptype: `%`(ret_val) + -- fun_subst_heaptype: `%%%%`(heaptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype, var_2 : reftype}: + `%%%%`(reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_reftype: `%`(ret_val) + -- fun_subst_reftype: `%%%%`(reftype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype, var_2 : valtype}: + `%%%%`(valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_valtype: `%`(ret_val) + -- fun_subst_valtype: `%%%%`(valtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype, var_2 : storagetype}: + `%%%%`(storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_storagetype: `%`(ret_val) + -- fun_subst_storagetype: `%%%%`(storagetype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype, var_2 : fieldtype}: + `%%%%`(fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_fieldtype: `%`(ret_val) + -- fun_subst_fieldtype: `%%%%`(fieldtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype, var_2 : comptype}: + `%%%%`(comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_comptype: `%`(ret_val) + -- fun_subst_comptype: `%%%%`(comptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype, var_2 : subtype}: + `%%%%`(subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_subtype: `%`(ret_val) + -- fun_subst_subtype: `%%%%`(subtype, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = at + def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}) = at ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tagtype(tagtype : tagtype, typevar*, typeuse*) : tagtype +relation fun_subst_tagtype: `%%%%`(tagtype, typevar*, typeuse*, tagtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = $subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) + rule fun_subst_tagtype_case_0{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_0 : tagtype}: + `%%%%`(tu', tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_globaltype(globaltype : globaltype, typevar*, typeuse*) : globaltype +relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*}(`%%`_globaltype(mut?{mut <- `mut?`}, t), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, $subst_valtype(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#2?{mut#2 <- `mut?`}, t), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype +relation subst_globaltype_is_wf: `%%%%`(globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + rule subst_globaltype_is_wf_0{globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype, var_2 : globaltype}: + `%%%%`(globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_globaltype: `%`(ret_val) + -- fun_subst_globaltype: `%%%%`(globaltype, var_0, var_1, var_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype +def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*}(`%%%`_tabletype(at, lim, rt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + def $subst_memtype{at : addrtype, lim : limits, `tv*` : typevar*, `tu*` : typeuse*}(`%%PAGE`_memtype(at, lim), tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}) = `%%PAGE`_memtype(at, lim) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(TAG_externtype(jt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*}(GLOBAL_externtype(gt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) +relation subst_memtype_is_wf: `%%%%`(memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*}(TABLE_externtype(tt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*}(MEM_externtype(mt), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*}(FUNC_externtype(tu'), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`})) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) + rule subst_memtype_is_wf_0{memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype +relation fun_subst_tabletype: `%%%%`(tabletype, typevar*, typeuse*, tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*}(`%->%`_moduletype(xt_1*{xt_1 <- `xt_1*`}, xt_2*{xt_2 <- `xt_2*`}), tv*{tv <- `tv*`}, tu*{tu <- `tu*`}) = `%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_1 <- `xt_1*`}, $subst_externtype(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`})*{xt_2 <- `xt_2*`})) + rule fun_subst_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(valtype : valtype, typeuse*) : valtype +relation subst_tabletype_is_wf: `%%%%`(tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, n : nat, `tu*` : typeuse*, i : nat}(t, tu^n{tu <- `tu*`}) = $subst_valtype(t, _IDX_typevar(`%`_typeidx(i))^(i%`_moduletype(xt_1#1*{xt_1#1 <- `xt_1*`}, xt_2#1*{xt_2#1 <- `xt_2*`}), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%->%`_moduletype(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} + -- if (|`var_1*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} + -- if (|`var_0*`| = |`xt_1*`|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_moduletype_is_wf: `%%%%`(moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_moduletype_is_wf_0{moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype, var_2 : moduletype}: + `%%%%`(moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_moduletype: `%`(ret_val) + -- fun_subst_moduletype: `%%%%`(moduletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_all_valtype: `%%%`(valtype, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_all_valtype_case_0{t : valtype, n : nat, `tu*` : typeuse*, i : nat, var_0 : valtype}: + `%%%`(t, tu#71*{tu#71 <- `tu*`}, var_0) + -- if (n = |`tu*`|) + -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i%`_comptype(resulttype_1, resulttype_2), var_0 +++ var_1) + -- fun_free_resulttype: `%%`(resulttype_2, var_1) + -- fun_free_resulttype: `%%`(resulttype_1, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation fun_free_subtype: `%%`(subtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule fun_free_subtype_case_0{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(SUB_subtype(final#2?{final#2 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(comptype, var_2) + -- (fun_free_typeuse: `%%`(typeuse, var_1))*{var_1 <- `var_1*`, typeuse <- `typeuse*`} + -- if (|`var_1*`| = |`typeuse*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation fun_free_rectype: `%%`(rectype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule fun_free_rectype_case_0{`subtype*` : subtype*, `var_1*` : free*, var_0 : free}: + `%%`(REC_rectype(`%`_list(subtype#5*{subtype#5 <- `subtype*`})), var_0) + -- (fun_free_subtype: `%%`(subtype, var_1))*{var_1 <- `var_1*`, subtype <- `subtype*`} + -- if (|`var_1*`| = |`subtype*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation fun_free_deftype: `%%`(deftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule fun_free_deftype_case_0{rectype : rectype, n : nat, var_0 : free}: + `%%`(_DEF_deftype(rectype, n), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) +} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.1-481.36 -def $free_heaptype(heaptype : heaptype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:529.1-529.65 - def $free_heaptype{absheaptype : absheaptype}((absheaptype : absheaptype <: heaptype)) = $free_absheaptype(absheaptype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:530.1-530.53 - def $free_heaptype{typeuse : typeuse}((typeuse : typeuse <: heaptype)) = $free_typeuse(typeuse) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.1-482.34 -def $free_reftype(reftype : reftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:532.1-532.65 - def $free_reftype{`null?` : null?, heaptype : heaptype}(REF_reftype(null?{null <- `null?`}, heaptype)) = $free_heaptype(heaptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.1-484.34 -def $free_typeuse(typeuse : typeuse) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:526.1-526.52 - def $free_typeuse{typevar : typevar}((typevar : typevar <: typeuse)) = $free_typevar(typevar) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:527.1-527.52 - def $free_typeuse{deftype : deftype}((deftype : deftype <: typeuse)) = $free_deftype(deftype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.1-485.34 -def $free_valtype(valtype : valtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:534.1-534.52 - def $free_valtype{numtype : numtype}((numtype : numtype <: valtype)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:535.1-535.52 - def $free_valtype{vectype : vectype}((vectype : vectype <: valtype)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:536.1-536.52 - def $free_valtype{reftype : reftype}((reftype : reftype <: valtype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:537.1-537.28 - def $free_valtype(BOT_valtype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.1-487.40 -def $free_resulttype(resulttype : resulttype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:539.1-539.69 - def $free_resulttype{`valtype*` : valtype*}(`%`_resulttype(valtype*{valtype <- `valtype*`})) = $free_list($free_valtype(valtype)*{valtype <- `valtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.1-488.42 -def $free_storagetype(storagetype : storagetype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:541.1-541.56 - def $free_storagetype{valtype : valtype}((valtype : valtype <: storagetype)) = $free_valtype(valtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:542.1-542.59 - def $free_storagetype{packtype : packtype}((packtype : packtype <: storagetype)) = $free_packtype(packtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.1-489.38 -def $free_fieldtype(fieldtype : fieldtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:544.1-544.71 - def $free_fieldtype{`mut?` : mut?, storagetype : storagetype}(`%%`_fieldtype(mut?{mut <- `mut?`}, storagetype)) = $free_storagetype(storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.1-490.36 -def $free_comptype(comptype : comptype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:546.1-546.80 - def $free_comptype{`fieldtype*` : fieldtype*}(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) = $free_list($free_fieldtype(fieldtype)*{fieldtype <- `fieldtype*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:547.1-547.65 - def $free_comptype{fieldtype : fieldtype}(ARRAY_comptype(fieldtype)) = $free_fieldtype(fieldtype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:548.1-548.121 - def $free_comptype{resulttype_1 : list(syntax valtype), resulttype_2 : list(syntax valtype)}(`FUNC%->%`_comptype(resulttype_1, resulttype_2)) = $free_resulttype(resulttype_1) +++ $free_resulttype(resulttype_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.1-491.34 -def $free_subtype(subtype : subtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:550.1-551.66 - def $free_subtype{`final?` : final?, `typeuse*` : typeuse*, comptype : comptype}(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) = $free_list($free_typeuse(typeuse)*{typeuse <- `typeuse*`}) +++ $free_comptype(comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.1-492.34 -def $free_rectype(rectype : rectype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:553.1-553.70 - def $free_rectype{`subtype*` : subtype*}(REC_rectype(`%`_list(subtype*{subtype <- `subtype*`}))) = $free_list($free_subtype(subtype)*{subtype <- `subtype*`}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.1-520.34 -def $free_deftype(deftype : deftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:521.1-521.59 - def $free_deftype{rectype : rectype, n : nat}(_DEF_deftype(rectype, n)) = $free_rectype(rectype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation free_heaptype_is_wf: `%%`(heaptype : heaptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule free_heaptype_is_wf_0{heaptype : heaptype, ret_val : free, var_0 : free}: + `%%`(heaptype, ret_val) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_heaptype: `%%`(heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation free_reftype_is_wf: `%%`(reftype : reftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule free_reftype_is_wf_0{reftype : reftype, ret_val : free, var_0 : free}: + `%%`(reftype, ret_val) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation free_typeuse_is_wf: `%%`(typeuse : typeuse, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule free_typeuse_is_wf_0{typeuse : typeuse, ret_val : free, var_0 : free}: + `%%`(typeuse, ret_val) + -- wf_typeuse: `%`(typeuse) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation free_valtype_is_wf: `%%`(valtype : valtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule free_valtype_is_wf_0{valtype : valtype, ret_val : free, var_0 : free}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_valtype: `%%`(valtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation free_resulttype_is_wf: `%%`(resulttype : resulttype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule free_resulttype_is_wf_0{resulttype : resulttype, ret_val : free, var_0 : free}: + `%%`(resulttype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_resulttype: `%%`(resulttype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation free_storagetype_is_wf: `%%`(storagetype : storagetype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule free_storagetype_is_wf_0{storagetype : storagetype, ret_val : free, var_0 : free}: + `%%`(storagetype, ret_val) + -- wf_storagetype: `%`(storagetype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_storagetype: `%%`(storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation free_fieldtype_is_wf: `%%`(fieldtype : fieldtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule free_fieldtype_is_wf_0{fieldtype : fieldtype, ret_val : free, var_0 : free}: + `%%`(fieldtype, ret_val) + -- wf_fieldtype: `%`(fieldtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_fieldtype: `%%`(fieldtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation free_comptype_is_wf: `%%`(comptype : comptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule free_comptype_is_wf_0{comptype : comptype, ret_val : free, var_0 : free}: + `%%`(comptype, ret_val) + -- wf_comptype: `%`(comptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_comptype: `%%`(comptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation free_subtype_is_wf: `%%`(subtype : subtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule free_subtype_is_wf_0{subtype : subtype, ret_val : free, var_0 : free}: + `%%`(subtype, ret_val) + -- wf_subtype: `%`(subtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_subtype: `%%`(subtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation free_rectype_is_wf: `%%`(rectype : rectype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule free_rectype_is_wf_0{rectype : rectype, ret_val : free, var_0 : free}: + `%%`(rectype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_rectype: `%%`(rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation free_deftype_is_wf: `%%`(deftype : deftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule free_deftype_is_wf_0{deftype : deftype, ret_val : free, var_0 : free}: + `%%`(deftype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_deftype: `%%`(deftype, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tagtype(tagtype : tagtype) : free +relation fun_free_tagtype: `%%`(tagtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tagtype_case_0{rectype : rectype, n : n, var_0 : free}: + `%%`(_DEF_tagtype(rectype, n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(rectype, n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tagtype_is_wf: `%%`(tagtype : tagtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tagtype_is_wf_0{tagtype : tagtype, ret_val : free, var_0 : free}: + `%%`(tagtype, ret_val) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tagtype: `%%`(tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_globaltype: `%%`(globaltype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{deftype : deftype}((deftype : deftype <: typeuse)) = $free_deftype(deftype) + rule fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_globaltype(globaltype : globaltype) : free +relation free_globaltype_is_wf: `%%`(globaltype : globaltype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_globaltype{`mut?` : mut?, valtype : valtype}(`%%`_globaltype(mut?{mut <- `mut?`}, valtype)) = $free_valtype(valtype) + rule free_globaltype_is_wf_0{globaltype : globaltype, ret_val : free, var_0 : free}: + `%%`(globaltype, ret_val) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_globaltype: `%%`(globaltype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_memtype(memtype : memtype) : free @@ -1938,38 +3346,118 @@ def $free_memtype(memtype : memtype) : free def $free_memtype{addrtype : addrtype, limits : limits}(`%%PAGE`_memtype(addrtype, limits)) = $free_addrtype(addrtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free +relation free_memtype_is_wf: `%%`(memtype : memtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_memtype_is_wf_0{memtype : memtype, ret_val : free}: + `%%`(memtype, ret_val) + -- wf_memtype: `%`(memtype) + -- if (ret_val = $free_memtype(memtype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_tabletype: `%%`(tabletype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tabletype_case_0{addrtype : addrtype, limits : limits, reftype : reftype, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), $free_addrtype(addrtype) +++ var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tabletype_is_wf: `%%`(tabletype : tabletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tabletype{addrtype : addrtype, limits : limits, reftype : reftype}(`%%%`_tabletype(addrtype, limits, reftype)) = $free_addrtype(addrtype) +++ $free_reftype(reftype) + rule free_tabletype_is_wf_0{tabletype : tabletype, ret_val : free, var_0 : free}: + `%%`(tabletype, ret_val) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tabletype: `%%`(tabletype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(datatype : datatype) : free ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(OK_datatype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_elemtype(elemtype : elemtype) : free +relation free_datatype_is_wf: `%%`(datatype : datatype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_datatype_is_wf_0{datatype : datatype, ret_val : free}: + `%%`(datatype, ret_val) + -- if (ret_val = $free_datatype(datatype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_elemtype: `%%`(elemtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_elemtype_case_0{reftype : reftype, var_0 : free}: + `%%`(reftype, var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_elemtype_is_wf: `%%`(elemtype : elemtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) + rule free_elemtype_is_wf_0{elemtype : elemtype, ret_val : free, var_0 : free}: + `%%`(elemtype, ret_val) + -- wf_reftype: `%`(elemtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemtype: `%%`(elemtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_externtype(externtype : externtype) : free +relation fun_free_externtype: `%%`(externtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tagtype : typeuse}(TAG_externtype(tagtype)) = $free_tagtype(tagtype) + rule fun_free_externtype_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_externtype(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_1{globaltype : globaltype, var_0 : free}: + `%%`(GLOBAL_externtype(globaltype), var_0) + -- fun_free_globaltype: `%%`(globaltype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_2{memtype : memtype}: + `%%`(MEM_externtype(memtype), $free_memtype(memtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) + rule fun_free_externtype_case_3{tabletype : tabletype, var_0 : free}: + `%%`(TABLE_externtype(tabletype), var_0) + -- fun_free_tabletype: `%%`(tabletype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) + rule fun_free_externtype_case_4{typeuse : typeuse, var_0 : free}: + `%%`(FUNC_externtype(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_externtype_is_wf: `%%`(externtype : externtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) + rule free_externtype_is_wf_0{externtype : externtype, ret_val : free, var_0 : free}: + `%%`(externtype, ret_val) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_moduletype: `%%`(moduletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) + rule fun_free_moduletype_case_0{`externtype_1*` : externtype*, `externtype_2*` : externtype*, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(`%->%`_moduletype(externtype_1#1*{externtype_1#1 <- `externtype_1*`}, externtype_2#1*{externtype_2#1 <- `externtype_2*`}), var_0 +++ var_2) + -- (fun_free_externtype: `%%`(externtype_2, var_3))*{var_3 <- `var_3*`, externtype_2 <- `externtype_2*`} + -- if (|`var_3*`| = |`externtype_2*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_externtype: `%%`(externtype_1, var_1))*{var_1 <- `var_1*`, externtype_1 <- `externtype_1*`} + -- if (|`var_1*`| = |`externtype_1*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_moduletype(moduletype : moduletype) : free +relation free_moduletype_is_wf: `%%`(moduletype : moduletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_moduletype{`externtype_1*` : externtype*, `externtype_2*` : externtype*}(`%->%`_moduletype(externtype_1*{externtype_1 <- `externtype_1*`}, externtype_2*{externtype_2 <- `externtype_2*`})) = $free_list($free_externtype(externtype_1)*{externtype_1 <- `externtype_1*`}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- `externtype_2*`}) + rule free_moduletype_is_wf_0{moduletype : moduletype, ret_val : free, var_0 : free}: + `%%`(moduletype, ret_val) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_moduletype: `%%`(moduletype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = @@ -1981,14 +3469,14 @@ relation wf_num_: `%%`(numtype, num_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule num__case_0{numtype : numtype, Inn : Inn, var_x : iN}: `%%`(numtype, mk_num__0_num_(Inn, var_x)) - -- wf_uN: `%%`($size((Inn : addrtype <: numtype)), var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- wf_uN: `%%`($size($numtype_addrtype(Inn)), var_x) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule num__case_1{numtype : numtype, Fnn : Fnn, var_x : fN}: `%%`(numtype, mk_num__1_num_(Fnn, var_x)) - -- wf_fN: `%%`($sizenn((Fnn : Fnn <: numtype)), var_x) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- wf_fN: `%%`($sizenn($numtype_Fnn(Fnn)), var_x) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_num__0(var_x : num_) : iN? @@ -2019,19 +3507,19 @@ relation wf_lane_: `%%`(lanetype, lane_) rule lane__case_0{lanetype : lanetype, numtype : numtype, var_x : num_}: `%%`(lanetype, mk_lane__0_lane_(numtype, var_x)) -- wf_num_: `%%`(numtype, var_x) - -- if (lanetype = (numtype : numtype <: lanetype)) + -- if (lanetype = $lanetype_numtype(numtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lane__case_1{lanetype : lanetype, packtype : packtype, var_x : pack_}: `%%`(lanetype, mk_lane__1_lane_(packtype, var_x)) -- wf_uN: `%%`($psize(packtype), var_x) - -- if (lanetype = (packtype : packtype <: lanetype)) + -- if (lanetype = $lanetype_packtype(packtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lane__case_2{lanetype : lanetype, Jnn : Jnn, var_x : iN}: `%%`(lanetype, mk_lane__2_lane_(Jnn, var_x)) - -- wf_uN: `%%`($lsize((Jnn : Jnn <: lanetype)), var_x) - -- if (lanetype = (Jnn : Jnn <: lanetype)) + -- wf_uN: `%%`($lsize($lanetype_Jnn(Jnn)), var_x) + -- if (lanetype = $lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_lane__0(var_x : lane_) : num_? @@ -2069,19 +3557,19 @@ relation wf_lit_: `%%`(storagetype, lit_) rule lit__case_0{storagetype : storagetype, numtype : numtype, var_x : num_}: `%%`(storagetype, mk_lit__0_lit_(numtype, var_x)) -- wf_num_: `%%`(numtype, var_x) - -- if (storagetype = (numtype : numtype <: storagetype)) + -- if (storagetype = $storagetype_numtype(numtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lit__case_1{storagetype : storagetype, vectype : vectype, var_x : vec_}: `%%`(storagetype, mk_lit__1_lit_(vectype, var_x)) -- wf_uN: `%%`($vsize(vectype), var_x) - -- if (storagetype = (vectype : vectype <: storagetype)) + -- if (storagetype = $storagetype_vectype(vectype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule lit__case_2{storagetype : storagetype, packtype : packtype, var_x : pack_}: `%%`(storagetype, mk_lit__2_lit_(packtype, var_x)) -- wf_uN: `%%`($psize(packtype), var_x) - -- if (storagetype = (packtype : packtype <: storagetype)) + -- if (storagetype = $storagetype_packtype(packtype)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_lit__0(var_x : lit_) : num_? @@ -2108,6 +3596,11 @@ def $proj_lit__2(var_x : lit_) : pack_? syntax sz = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +def $proj_sz_0(x : sz) : (nat) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $proj_sz_0{v_num_0 : nat}(`%`_sz(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_sz: `%`(sz) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2145,7 +3638,7 @@ relation wf_unop_Inn: `%%`(Inn, unop_Inn) rule unop_Inn_case_3{Inn : Inn, sz : sz}: `%%`(Inn, EXTEND_unop_Inn(sz)) -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax unop_Fnn = @@ -2168,12 +3661,12 @@ relation wf_unop_: `%%`(numtype, unop_) rule unop__case_0{numtype : numtype, Inn : Inn, var_x : unop_Inn}: `%%`(numtype, mk_unop__0_unop_(Inn, var_x)) -- wf_unop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule unop__case_1{numtype : numtype, Fnn : Fnn, var_x : unop_Fnn}: `%%`(numtype, mk_unop__1_unop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_unop__0(var_x : unop_) : unop_Inn? @@ -2224,12 +3717,12 @@ relation wf_binop_: `%%`(numtype, binop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule binop__case_0{numtype : numtype, Inn : Inn, var_x : binop_Inn}: `%%`(numtype, mk_binop__0_binop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule binop__case_1{numtype : numtype, Fnn : Fnn, var_x : binop_Fnn}: `%%`(numtype, mk_binop__1_binop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_binop__0(var_x : binop_) : binop_Inn? @@ -2258,7 +3751,7 @@ relation wf_testop_: `%%`(numtype, testop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule testop__case_0{numtype : numtype, Inn : Inn, var_x : testop_Inn}: `%%`(numtype, mk_testop__0_testop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_testop__0(var_x : testop_) : testop_Inn @@ -2293,12 +3786,12 @@ relation wf_relop_: `%%`(numtype, relop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule relop__case_0{numtype : numtype, Inn : Inn, var_x : relop_Inn}: `%%`(numtype, mk_relop__0_relop_(Inn, var_x)) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule relop__case_1{numtype : numtype, Fnn : Fnn, var_x : relop_Fnn}: `%%`(numtype, mk_relop__1_relop_(Fnn, var_x)) - -- if (numtype = (Fnn : Fnn <: numtype)) + -- if (numtype = $numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_relop__0(var_x : relop_) : relop_Inn? @@ -2324,12 +3817,12 @@ relation wf_cvtop__Inn_1_Inn_2: `%%%`(Inn, Inn, cvtop__Inn_1_Inn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Inn_2_case_0{Inn_1 : Inn, Inn_2 : Inn, sx : sx}: `%%%`(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) < $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) < $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Inn_2_case_1{Inn_1 : Inn, Inn_2 : Inn}: `%%%`(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) > $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) > $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Inn_1_Fnn_2 = @@ -2345,7 +3838,7 @@ relation wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn, Fnn, cvtop__Inn_1_Fnn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Inn_1_Fnn_2_case_1{Inn_1 : Inn, Fnn_2 : Fnn}: `%%%`(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2) - -- if ($sizenn1((Inn_1 : addrtype <: numtype)) = $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_addrtype(Inn_1)) = $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Fnn_1_Inn_2 = @@ -2366,7 +3859,7 @@ relation wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn, Inn, cvtop__Fnn_1_Inn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Inn_2_case_2{Fnn_1 : Fnn, Inn_2 : Inn}: `%%%`(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = $sizenn2((Inn_2 : addrtype <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) = $sizenn2($numtype_addrtype(Inn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__Fnn_1_Fnn_2 = @@ -2378,12 +3871,12 @@ relation wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn, Fnn, cvtop__Fnn_1_Fnn_2) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Fnn_2_case_0{Fnn_1 : Fnn, Fnn_2 : Fnn}: `%%%`(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) < $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) < $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop__Fnn_1_Fnn_2_case_1{Fnn_1 : Fnn, Fnn_2 : Fnn}: `%%%`(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) > $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) > $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax cvtop__ = @@ -2398,29 +3891,29 @@ relation wf_cvtop__: `%%%`(numtype, numtype, cvtop__) rule cvtop___case_0{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Inn_2 : Inn, var_x : cvtop__Inn_1_Inn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___0_cvtop__(Inn_1, Inn_2, var_x)) -- wf_cvtop__Inn_1_Inn_2: `%%%`(Inn_1, Inn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) + -- if (numtype_1 = $numtype_addrtype(Inn_1)) + -- if (numtype_2 = $numtype_addrtype(Inn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_1{numtype_1 : numtype, numtype_2 : numtype, Inn_1 : Inn, Fnn_2 : Fnn, var_x : cvtop__Inn_1_Fnn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___1_cvtop__(Inn_1, Fnn_2, var_x)) -- wf_cvtop__Inn_1_Fnn_2: `%%%`(Inn_1, Fnn_2, var_x) - -- if (numtype_1 = (Inn_1 : addrtype <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) + -- if (numtype_1 = $numtype_addrtype(Inn_1)) + -- if (numtype_2 = $numtype_Fnn(Fnn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_2{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Inn_2 : Inn, var_x : cvtop__Fnn_1_Inn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___2_cvtop__(Fnn_1, Inn_2, var_x)) -- wf_cvtop__Fnn_1_Inn_2: `%%%`(Fnn_1, Inn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Inn_2 : addrtype <: numtype)) + -- if (numtype_1 = $numtype_Fnn(Fnn_1)) + -- if (numtype_2 = $numtype_addrtype(Inn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule cvtop___case_3{numtype_1 : numtype, numtype_2 : numtype, Fnn_1 : Fnn, Fnn_2 : Fnn, var_x : cvtop__Fnn_1_Fnn_2}: `%%%`(numtype_1, numtype_2, mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, var_x)) -- wf_cvtop__Fnn_1_Fnn_2: `%%%`(Fnn_1, Fnn_2, var_x) - -- if (numtype_1 = (Fnn_1 : Fnn <: numtype)) - -- if (numtype_2 = (Fnn_2 : Fnn <: numtype)) + -- if (numtype_1 = $numtype_Fnn(Fnn_1)) + -- if (numtype_2 = $numtype_Fnn(Fnn_2)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_cvtop___0(var_x : cvtop__) : cvtop__Inn_1_Inn_2? @@ -2454,6 +3947,11 @@ def $proj_cvtop___3(var_x : cvtop__) : cvtop__Fnn_1_Fnn_2? syntax dim = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +def $proj_dim_0(x : dim) : (nat) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $proj_dim_0{v_num_0 : nat}(`%`_dim(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_dim: `%`(dim) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2471,13 +3969,21 @@ relation wf_shape: `%`(shape) rule shape_case_0{lanetype : lanetype, dim : dim}: `%`(`%X%`_shape(lanetype, dim)) -- wf_dim: `%`(dim) - -- if (($lsize(lanetype) * dim!`%`_dim.0) = 128) + -- if (($lsize(lanetype) * $proj_dim_0(dim).0) = 128) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim(shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) - -- wf_dim: `%`(`%`_dim(N)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{shape : shape, ret_val : dim}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $dim(shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $lanetype(shape : shape) : lanetype @@ -2493,18 +3999,28 @@ def $unpackshape(shape : shape) : numtype syntax ishape = | `%`(shape : shape) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +def $proj_ishape_0(x : ishape) : (shape) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $proj_ishape_0{v_shape_0 : shape}(`%`_ishape(v_shape_0)) = (v_shape_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_ishape: `%`(ishape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule ishape_case_0{Jnn : Jnn, shape : shape}: `%`(`%`_ishape(shape)) -- wf_shape: `%`(shape) - -- if ($lanetype(shape) = (Jnn : Jnn <: lanetype)) + -- if ($lanetype(shape) = $lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax bshape = | `%`(shape : shape) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +def $proj_bshape_0(x : bshape) : (shape) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $proj_bshape_0{v_shape_0 : shape}(`%`_bshape(v_shape_0)) = (v_shape_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_bshape: `%`(bshape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2560,7 +4076,7 @@ relation wf_vunop_Jnn_M: `%%%`(Jnn, M, vunop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vunop_Jnn_M_case_2{Jnn : Jnn, M : M}: `%%%`(Jnn, M, POPCNT_vunop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 8) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 8) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vunop_Fnn_M = @@ -2583,12 +4099,12 @@ relation wf_vunop_: `%%`(shape, vunop_) rule vunop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vunop_Jnn_M}: `%%`(shape, mk_vunop__0_vunop_(Jnn, M, var_x)) -- wf_vunop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vunop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vunop_Fnn_M}: `%%`(shape, mk_vunop__1_vunop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vunop__0(var_x : vunop_) : vunop_Jnn_M? @@ -2630,42 +4146,42 @@ relation wf_vbinop_Jnn_M: `%%%`(Jnn, M, vbinop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_4{Jnn : Jnn, M : M}: `%%%`(Jnn, M, MUL_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) >= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) >= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_5{Jnn : Jnn, M : M}: `%%%`(Jnn, M, AVGRU_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_6{Jnn : Jnn, M : M}: `%%%`(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_7{Jnn : Jnn, M : M}: `%%%`(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) = 16) + -- if ($lsizenn($lanetype_Jnn(Jnn)) = 16) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_8{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, MIN_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 32) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop_Jnn_M_case_9{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, MAX_vbinop_Jnn_M(sx)) - -- if ($lsizenn((Jnn : Jnn <: lanetype)) <= 32) + -- if ($lsizenn($lanetype_Jnn(Jnn)) <= 32) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vbinop_Fnn_M = @@ -2691,12 +4207,12 @@ relation wf_vbinop_: `%%`(shape, vbinop_) rule vbinop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vbinop_Jnn_M}: `%%`(shape, mk_vbinop__0_vbinop_(Jnn, M, var_x)) -- wf_vbinop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vbinop_Fnn_M}: `%%`(shape, mk_vbinop__1_vbinop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vbinop__0(var_x : vbinop_) : vbinop_Jnn_M? @@ -2731,12 +4247,12 @@ relation wf_vternop_: `%%`(shape, vternop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vternop_Jnn_M}: `%%`(shape, mk_vternop__0_vternop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vternop_Fnn_M}: `%%`(shape, mk_vternop__1_vternop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vternop__0(var_x : vternop_) : vternop_Jnn_M? @@ -2765,7 +4281,7 @@ relation wf_vtestop_: `%%`(shape, vtestop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vtestop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vtestop_Jnn_M}: `%%`(shape, mk_vtestop__0_vtestop_(Jnn, M, var_x)) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vtestop__0(var_x : vtestop_) : vtestop_Jnn_M @@ -2794,22 +4310,22 @@ relation wf_vrelop_Jnn_M: `%%%`(Jnn, M, vrelop_Jnn_M) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_2{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, LT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_3{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, GT_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_4{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, LE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop_Jnn_M_case_5{Jnn : Jnn, M : M, sx : sx}: `%%%`(Jnn, M, GE_vrelop_Jnn_M(sx)) - -- if (($lsizenn((Jnn : Jnn <: lanetype)) =/= 64) \/ (sx = S_sx)) + -- if (($lsizenn($lanetype_Jnn(Jnn)) =/= 64) \/ (sx = S_sx)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vrelop_Fnn_M = @@ -2831,12 +4347,12 @@ relation wf_vrelop_: `%%`(shape, vrelop_) rule vrelop__case_0{shape : shape, Jnn : Jnn, M : M, var_x : vrelop_Jnn_M}: `%%`(shape, mk_vrelop__0_vrelop_(Jnn, M, var_x)) -- wf_vrelop_Jnn_M: `%%%`(Jnn, M, var_x) - -- if (shape = `%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop__case_1{shape : shape, Fnn : Fnn, M : M, var_x : vrelop_Fnn_M}: `%%`(shape, mk_vrelop__1_vrelop_(Fnn, M, var_x)) - -- if (shape = `%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + -- if (shape = `%X%`_shape($lanetype_Fnn(Fnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vrelop__0(var_x : vrelop_) : vrelop_Jnn_M? @@ -2866,7 +4382,7 @@ relation wf_vshiftop_: `%%`(ishape, vshiftop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vshiftop__case_0{ishape : ishape, Jnn : Jnn, M : M, var_x : vshiftop_Jnn_M}: `%%`(ishape, mk_vshiftop__0_vshiftop_(Jnn, M, var_x)) - -- if (ishape = `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) + -- if (ishape = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vshiftop__0(var_x : vshiftop_) : vshiftop_Jnn_M @@ -2903,7 +4419,7 @@ relation wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextunop__Jnn ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextunop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)) - -- if ((16 <= (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) <= 32))) + -- if ((16 <= (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) /\ (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) <= 32))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextunop__ = @@ -2915,8 +4431,8 @@ relation wf_vextunop__: `%%%`(ishape, ishape, vextunop__) rule vextunop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextunop___0(var_x : vextunop__) : vextunop__Jnn_1_M_1_Jnn_2_M_2 @@ -2934,17 +4450,17 @@ relation wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextbinop__J ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) >= 16)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) >= 16)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_1{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextbinop__Jnn_1_M_1_Jnn_2_M_2_case_2{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((2 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 16)) + -- if (((2 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 16)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextbinop__ = @@ -2956,8 +4472,8 @@ relation wf_vextbinop__: `%%%`(ishape, ishape, vextbinop__) rule vextbinop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextbinop___0(var_x : vextbinop__) : vextbinop__Jnn_1_M_1_Jnn_2_M_2 @@ -2973,7 +4489,7 @@ relation wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vextternop_ ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vextternop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2) - -- if (((4 * $lsizenn1((Jnn_1 : Jnn <: lanetype))) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) + -- if (((4 * $lsizenn1($lanetype_Jnn(Jnn_1))) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vextternop__ = @@ -2985,8 +4501,8 @@ relation wf_vextternop__: `%%%`(ishape, ishape, vextternop__) rule vextternop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) + -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) + -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextternop___0(var_x : vextternop__) : vextternop__Jnn_1_M_1_Jnn_2_M_2 @@ -3002,7 +4518,7 @@ relation wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn, M, Jnn, M, vcvtop__Jnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Jnn_1_M_1_Jnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, half : half, sx : sx}: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)) - -- if ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) + -- if ($lsizenn2($lanetype_Jnn(Jnn_2)) = (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Jnn_1_M_1_Fnn_2_M_2 = @@ -3013,7 +4529,7 @@ relation wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn, M, Fnn, M, vcvtop__Jnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Jnn_1_M_1_Fnn_2_M_2_case_0{Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, `half?` : half?, sx : sx}: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(`half?`, sx)) - -- if (((($sizenn2((Fnn_2 : Fnn <: numtype)) = $lsizenn1((Jnn_1 : Jnn <: lanetype))) /\ ($lsizenn1((Jnn_1 : Jnn <: lanetype)) = 32)) /\ (half?{half <- `half?`} = ?())) \/ (($sizenn2((Fnn_2 : Fnn <: numtype)) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) /\ (half?{half <- `half?`} = ?(LOW_half)))) + -- if (((($sizenn2($numtype_Fnn(Fnn_2)) = $lsizenn1($lanetype_Jnn(Jnn_1))) /\ ($lsizenn1($lanetype_Jnn(Jnn_1)) = 32)) /\ (half?{half <- `half?`} = ?())) \/ (($sizenn2($numtype_Fnn(Fnn_2)) = (2 * $lsizenn1($lanetype_Jnn(Jnn_1)))) /\ (half?{half <- `half?`} = ?(LOW_half)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Fnn_1_M_1_Jnn_2_M_2 = @@ -3025,12 +4541,12 @@ relation wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn, M, Jnn, M, vcvtop__Fnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) + -- if (((($sizenn1($numtype_Fnn(Fnn_1)) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $lsizenn2($lanetype_Jnn(Jnn_2)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Jnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, sx : sx, `zero?` : zero?}: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, `zero?`)) - -- if (((($sizenn1((Fnn_1 : Fnn <: numtype)) = $lsizenn2((Jnn_2 : Jnn <: lanetype))) /\ ($lsizenn2((Jnn_2 : Jnn <: lanetype)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $lsizenn2((Jnn_2 : Jnn <: lanetype)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) + -- if (((($sizenn1($numtype_Fnn(Fnn_1)) = $lsizenn2($lanetype_Jnn(Jnn_2))) /\ ($lsizenn2($lanetype_Jnn(Jnn_2)) = 32)) /\ (zero?{zero <- `zero?`} = ?())) \/ (($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $lsizenn2($lanetype_Jnn(Jnn_2)))) /\ (zero?{zero <- `zero?`} = ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__Fnn_1_M_1_Fnn_2_M_2 = @@ -3042,12 +4558,12 @@ relation wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn, M, Fnn, M, vcvtop__Fnn_1_M ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_0{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, zero : zero}: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)) - -- if ($sizenn1((Fnn_1 : Fnn <: numtype)) = (2 * $sizenn2((Fnn_2 : Fnn <: numtype)))) + -- if ($sizenn1($numtype_Fnn(Fnn_1)) = (2 * $sizenn2($numtype_Fnn(Fnn_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop__Fnn_1_M_1_Fnn_2_M_2_case_1{Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M}: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2) - -- if ((2 * $sizenn1((Fnn_1 : Fnn <: numtype))) = $sizenn2((Fnn_2 : Fnn <: numtype))) + -- if ((2 * $sizenn1($numtype_Fnn(Fnn_1))) = $sizenn2($numtype_Fnn(Fnn_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax vcvtop__ = @@ -3062,29 +4578,29 @@ relation wf_vcvtop__: `%%%`(shape, shape, vcvtop__) rule vcvtop___case_0{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_1{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_2{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_3{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vcvtop___0(var_x : vcvtop__) : vcvtop__Jnn_1_M_1_Jnn_2_M_2? @@ -3139,7 +4655,7 @@ relation wf_loadop_Inn: `%%`(Inn, loadop_Inn) rule loadop_Inn_case_0{Inn : Inn, sz : sz, sx : sx}: `%%`(Inn, `%_%`_loadop_Inn(sz, sx)) -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax loadop_ = @@ -3151,7 +4667,7 @@ relation wf_loadop_: `%%`(numtype, loadop_) rule loadop__case_0{numtype : numtype, Inn : Inn, var_x : loadop_Inn}: `%%`(numtype, mk_loadop__0_loadop_(Inn, var_x)) -- wf_loadop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_loadop__0(var_x : loadop_) : loadop_Inn @@ -3168,7 +4684,7 @@ relation wf_storeop_Inn: `%%`(Inn, storeop_Inn) rule storeop_Inn_case_0{Inn : Inn, sz : sz}: `%%`(Inn, `%`_storeop_Inn(sz)) -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 < $sizenn((Inn : addrtype <: numtype))) + -- if ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax storeop_ = @@ -3180,7 +4696,7 @@ relation wf_storeop_: `%%`(numtype, storeop_) rule storeop__case_0{numtype : numtype, Inn : Inn, var_x : storeop_Inn}: `%%`(numtype, mk_storeop__0_storeop_(Inn, var_x)) -- wf_storeop_Inn: `%%`(Inn, var_x) - -- if (numtype = (Inn : addrtype <: numtype)) + -- if (numtype = $numtype_addrtype(Inn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_storeop__0(var_x : storeop_) : storeop_Inn @@ -3199,7 +4715,7 @@ relation wf_vloadop_: `%%`(vectype, vloadop_) rule vloadop__case_0{vectype : vectype, sz : sz, M : M, sx : sx}: `%%`(vectype, `SHAPE%X%_%`_vloadop_(sz, M, sx)) -- wf_sz: `%`(sz) - -- if (((sz!`%`_sz.0 * M) : nat <:> rat) = (($vsize(vectype) : nat <:> rat) / (2 : nat <:> rat))) + -- if ((($proj_sz_0(sz).0 * M) : nat <:> rat) = (($vsize(vectype) : nat <:> rat) / (2 : nat <:> rat))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vloadop__case_1{vectype : vectype, sz : sz}: @@ -3210,7 +4726,7 @@ relation wf_vloadop_: `%%`(vectype, vloadop_) rule vloadop__case_2{vectype : vectype, sz : sz}: `%%`(vectype, ZERO_vloadop_(sz)) -- wf_sz: `%`(sz) - -- if (sz!`%`_sz.0 >= 32) + -- if ($proj_sz_0(sz).0 >= 32) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax blocktype = @@ -3406,6 +4922,16 @@ syntax val = | `REF.HOST_ADDR`(hostaddr : hostaddr) | `REF.EXTERN`(ref : ref) +def $val_ref(ref) : val + def $val_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_val(x0) + def $val_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_val + def $val_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_val(x0) + def $val_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_val(x0) + def $val_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_val(x0) + def $val_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_val(x0) + def $val_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_val(x0) + def $val_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_val(x0) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_val: `%`(val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -3590,6 +5116,28 @@ syntax instr = | TRAP } +def $instr_ref(ref) : instr + def $instr_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_instr(x0) + def $instr_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_instr + def $instr_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_instr(x0) + def $instr_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_instr(x0) + def $instr_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_instr(x0) + def $instr_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_instr(x0) + def $instr_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_instr(x0) + def $instr_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_instr(x0) + +def $instr_val(val) : instr + def $instr_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_instr(x0, x1) + def $instr_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_instr(x0, x1) + def $instr_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_instr(x0) + def $instr_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_instr + def $instr_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_instr(x0) + def $instr_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_instr(x0) + def $instr_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_instr(x0) + def $instr_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_instr(x0) + def $instr_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_instr(x0) + def $instr_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_instr(x0) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -4102,7 +5650,7 @@ relation wf_instr: `%`(instr) `%`(VSHUFFLE_instr(bshape, `laneidx*`)) -- wf_bshape: `%`(bshape) -- (wf_uN: `%%`(8, laneidx))*{laneidx <- `laneidx*`} - -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = $dim(bshape!`%`_bshape.0)) + -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = $dim($proj_bshape_0(bshape).0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_96{ishape_1 : ishape, ishape_2 : ishape, var_0 : vextunop__}: @@ -4130,7 +5678,7 @@ relation wf_instr: `%`(instr) `%`(VNARROW_instr(ishape_1, ishape_2, sx)) -- wf_ishape: `%`(ishape_1) -- wf_ishape: `%`(ishape_2) - -- if (($lsize($lanetype(ishape_2!`%`_ishape.0)) = (2 * $lsize($lanetype(ishape_1!`%`_ishape.0)))) /\ ((2 * $lsize($lanetype(ishape_1!`%`_ishape.0))) <= 32)) + -- if (($lsize($lanetype($proj_ishape_0(ishape_2).0)) = (2 * $lsize($lanetype($proj_ishape_0(ishape_1).0)))) /\ ((2 * $lsize($lanetype($proj_ishape_0(ishape_1).0))) <= 32)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_100{shape_1 : shape, shape_2 : shape, var_0 : vcvtop__}: @@ -4150,6 +5698,7 @@ relation wf_instr: `%`(instr) -- wf_shape: `%`(shape) -- wf_uN: `%%`(8, laneidx) -- if ((sx?{sx <- `sx?`} = ?()) <=> ($lanetype(shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) + -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_103{shape : shape, laneidx : laneidx}: @@ -4221,16 +5770,36 @@ syntax expr = instr* def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(consttype : consttype, lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) + def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $const{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(consttype : consttype, lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{consttype : consttype, lit_ : lit_, ret_val : instr}: + `%%%`(consttype, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_consttype(consttype), lit_) + -- if (ret_val = $const(consttype, lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(shape : shape) : free @@ -4238,11 +5807,35 @@ def $free_shape(shape : shape) : free def $free_shape{lanetype : lanetype, dim : dim}(`%X%`_shape(lanetype, dim)) = $free_lanetype(lanetype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free +relation free_shape_is_wf: `%%`(shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{shape : shape, ret_val : free}: + `%%`(shape, ret_val) + -- wf_shape: `%`(shape) + -- if (ret_val = $free_shape(shape)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_free_blocktype: `%%`(blocktype, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_0{`valtype?` : valtype?, `var_0?` : free?}: + `%%`(_RESULT_blocktype(valtype#504?{valtype#504 <- `valtype?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_0))?{var_0 <- `var_0?`, valtype <- `valtype?`} + -- if ((`var_0?` = ?()) <=> (`valtype?` = ?())) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{`valtype?` : valtype?}(_RESULT_blocktype(valtype?{valtype <- `valtype?`})) = $free_opt($free_valtype(valtype)?{valtype <- `valtype?`}) + rule fun_free_blocktype_case_1{typeidx : uN}: + `%%`(_IDX_blocktype(typeidx), $free_typeidx(typeidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(blocktype : blocktype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) + rule free_blocktype_is_wf_0{blocktype : blocktype, ret_val : free, var_0 : free}: + `%%`(blocktype, ret_val) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_blocktype: `%%`(blocktype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(catch : catch) : free @@ -4255,258 +5848,539 @@ def $free_catch(catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{catch : catch, ret_val : free}: + `%%`(catch, ret_val) + -- wf_catch: `%`(catch) + -- if (ret_val = $free_catch(catch)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 +relation fun_shift_labelidxs: `%%`(labelidx*, labelidx*) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_1{`labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([`%`_labelidx(0)] ++ labelidx'#1*{labelidx'#1 <- `labelidx'*`}, var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_2{labelidx : uN, `labelidx'*` : labelidx*, var_0 : labelidx*}: + `%%`([labelidx] ++ labelidx'#2*{labelidx'#2 <- `labelidx'*`}, [`%`_labelidx(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.1-584.44 -def $shift_labelidxs(labelidx*) : labelidx* - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:585.1-585.32 - def $shift_labelidxs([]) = [] - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:586.1-586.66 - def $shift_labelidxs{`labelidx'*` : labelidx*}([`%`_labelidx(0)] ++ labelidx'*{labelidx' <- `labelidx'*`}) = $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 - def $shift_labelidxs{labelidx : uN, `labelidx'*` : labelidx*}([labelidx] ++ labelidx'*{labelidx' <- `labelidx'*`}) = [`%`_labelidx((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'*{labelidx' <- `labelidx'*`}) - -- wf_uN: `%%`(32, `%`_uN((((labelidx!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation fun_free_instr: `%%`(instr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_0: + `%%`(NOP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_1: + `%%`(UNREACHABLE_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_2: + `%%`(DROP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{`valtype*?` : valtype*?, `var_1*?` : free*?, `var_0?` : free?}: + `%%`(SELECT_instr(valtype#505*{valtype#505 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), $free_opt(var_0?{var_0 <- `var_0?`})) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `valtype*`}?{`var_1*` <- `var_1*?`, `valtype*` <- `valtype*?`} + -- if ((`var_1*?` = ?()) <=> (`valtype*?` = ?())) + -- (if (|`var_1*`| = |`valtype*`|))?{`var_1*` <- `var_1*?`, `valtype*` <- `valtype*?`} + -- (fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0))?{`var_1*` <- `var_1*?`, var_0 <- `var_0?`} + -- if ((`var_1*?` = ?()) <=> (`var_0?` = ?())) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_4{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(BLOCK_instr(blocktype, instr#1*{instr#1 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_5{blocktype : blocktype, `instr*` : instr*, var_1 : free, var_0 : free}: + `%%`(LOOP_instr(blocktype, instr#2*{instr#2 <- `instr*`}), var_0 +++ var_1) + -- fun_free_block: `%%`(instr*{instr <- `instr*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_6{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(`IF%%ELSE%`_instr(blocktype, instr_1#1*{instr_1#1 <- `instr_1*`}, instr_2#1*{instr_2#1 <- `instr_2*`}), var_0 +++ var_1 +++ var_2) + -- fun_free_block: `%%`(instr_2*{instr_2 <- `instr_2*`}, var_2) + -- fun_free_block: `%%`(instr_1*{instr_1 <- `instr_1*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_7{labelidx : uN}: + `%%`(BR_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN}: + `%%`(BR_IF_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ $free_labelidx(labelidx')) + -- fun_free_list: `%%`($free_labelidx(labelidx)*{labelidx <- `labelidx*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN}: + `%%`(BR_ON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN}: + `%%`(BR_ON_NON_NULL_instr(labelidx), $free_labelidx(labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_12{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_13{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), $free_labelidx(labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN}: + `%%`(CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_15{typeuse : typeuse, var_0 : free}: + `%%`(CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_16{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_17: + `%%`(RETURN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{funcidx : uN}: + `%%`(RETURN_CALL_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_19{typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_REF_instr(typeuse), var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_20{tableidx : uN, typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), $free_tableidx(tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN}: + `%%`(THROW_instr(tagidx), $free_tagidx(tagidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_22: + `%%`(THROW_REF_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_23{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*, `var_3*` : free*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(TRY_TABLE_instr(blocktype, `%`_list(catch#1*{catch#1 <- `catch*`}), instr#3*{instr#3 <- `instr*`}), var_0 +++ var_1 +++ var_2) + -- (fun_free_instr: `%%`(instr, var_3))*{var_3 <- `var_3*`, instr <- `instr*`} + -- if (|`var_3*`| = |`instr*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- fun_free_list: `%%`($free_catch(catch)*{catch <- `catch*`}, var_1) + -- fun_free_blocktype: `%%`(blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_24{numtype : numtype, numlit : num_}: + `%%`(CONST_instr(numtype, numlit), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_}: + `%%`(UNOP_instr(numtype, unop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_}: + `%%`(BINOP_instr(numtype, binop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_}: + `%%`(TESTOP_instr(numtype, testop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_}: + `%%`(RELOP_instr(numtype, relop), $free_numtype(numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_29{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), $free_numtype(numtype_1) +++ $free_numtype(numtype_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN}: + `%%`(VCONST_instr(vectype, veclit), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop}: + `%%`(VVUNOP_instr(vectype, vvunop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop}: + `%%`(VVBINOP_instr(vectype, vvbinop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop}: + `%%`(VVTERNOP_instr(vectype, vvternop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop}: + `%%`(VVTESTOP_instr(vectype, vvtestop), $free_vectype(vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_}: + `%%`(VUNOP_instr(shape, vunop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_}: + `%%`(VBINOP_instr(shape, vbinop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_}: + `%%`(VTERNOP_instr(shape, vternop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_}: + `%%`(VTESTOP_instr(shape, vtestop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_}: + `%%`(VRELOP_instr(shape, vrelop), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape}: + `%%`(VBITMASK_instr(ishape), $free_shape($proj_ishape_0(ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), $free_shape($proj_bshape_0(bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_44{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_45{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_46{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_47{ishape_1 : ishape, ishape_2 : ishape, sx : sx}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_48{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), $free_shape(shape_1) +++ $free_shape(shape_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape}: + `%%`(VSPLAT_instr(shape), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_50{shape : shape, `sx?` : sx?, laneidx : uN}: + `%%`(VEXTRACT_LANE_instr(shape, sx#45969?{sx#45969 <- `sx?`}, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), $free_shape(shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_52{heaptype : heaptype, var_0 : free}: + `%%`(`REF.NULL`_instr(heaptype), var_0) + -- fun_free_heaptype: `%%`(heaptype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_53: + `%%`(`REF.IS_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_54: + `%%`(`REF.AS_NON_NULL`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_55: + `%%`(`REF.EQ`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_56{reftype : reftype, var_0 : free}: + `%%`(`REF.TEST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_57{reftype : reftype, var_0 : free}: + `%%`(`REF.CAST`_instr(reftype), var_0) + -- fun_free_reftype: `%%`(reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_58{funcidx : uN}: + `%%`(`REF.FUNC`_instr(funcidx), $free_funcidx(funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_59: + `%%`(`REF.I31`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_60{sx : sx}: + `%%`(`I31.GET`_instr(sx), {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{typeidx : uN}: + `%%`(`STRUCT.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_63{`sx?` : sx?, typeidx : uN, u32 : uN}: + `%%`(`STRUCT.GET`_instr(sx#45970?{sx#45970 <- `sx?`}, typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN}: + `%%`(`ARRAY.NEW`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN}: + `%%`(`ARRAY.GET`_instr(sx#45971?{sx#45971 <- `sx?`}, typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN}: + `%%`(`ARRAY.SET`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_72: + `%%`(`ARRAY.LEN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{typeidx : uN}: + `%%`(`ARRAY.FILL`_instr(typeidx), $free_typeidx(typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_74{typeidx_1 : uN, typeidx_2 : uN}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), $free_typeidx(typeidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), $free_typeidx(typeidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_77: + `%%`(`EXTERN.CONVERT_ANY`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_78: + `%%`(`ANY.CONVERT_EXTERN`_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{localidx : uN}: + `%%`(`LOCAL.GET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN}: + `%%`(`LOCAL.SET`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN}: + `%%`(`LOCAL.TEE`_instr(localidx), $free_localidx(localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN}: + `%%`(`GLOBAL.GET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN}: + `%%`(`GLOBAL.SET`_instr(globalidx), $free_globalidx(globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN}: + `%%`(`TABLE.GET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN}: + `%%`(`TABLE.SET`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN}: + `%%`(`TABLE.SIZE`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN}: + `%%`(`TABLE.GROW`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN}: + `%%`(`TABLE.FILL`_instr(tableidx), $free_tableidx(tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_89{tableidx_1 : uN, tableidx_2 : uN}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), $free_tableidx(tableidx) +++ $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN}: + `%%`(`ELEM.DROP`_instr(elemidx), $free_elemidx(elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_92{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_93{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), $free_numtype(numtype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_94{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_95{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_96{vectype : vectype, memidx : uN, memarg : memarg}: + `%%`(VSTORE_instr(vectype, memidx, memarg), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_97{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), $free_vectype(vectype) +++ $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN}: + `%%`(`MEMORY.SIZE`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN}: + `%%`(`MEMORY.GROW`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN}: + `%%`(`MEMORY.FILL`_instr(memidx), $free_memidx(memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_101{memidx_1 : uN, memidx_2 : uN}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), $free_memidx(memidx_1) +++ $free_memidx(memidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), $free_memidx(memidx) +++ $free_dataidx(dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN}: + `%%`(`DATA.DROP`_instr(dataidx), $free_dataidx(dataidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation fun_free_block: `%%`(instr*, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule fun_free_block_case_0{`instr*` : instr*, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- let{free : free} free = var_1 + -- (fun_free_instr: `%%`(instr#5, var_2))*{var_2 <- `var_2*`, instr#5 <- `instr*`} + -- if (|`var_2*`| = |`instr*`|) + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_shift_labelidxs: `%%`(free.LABELS_free, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.1-420.30 -def $free_instr(instr : instr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 - def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 - def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 - def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{`valtype*?` : valtype*?}(SELECT_instr(valtype*{valtype <- `valtype*`}?{`valtype*` <- `valtype*?`})) = $free_opt($free_list($free_valtype(valtype)*{valtype <- `valtype*`})?{`valtype*` <- `valtype*?`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(BLOCK_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 - def $free_instr{blocktype : blocktype, `instr*` : instr*}(LOOP_instr(blocktype, instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_block(instr*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:442.1-443.79 - def $free_instr{blocktype : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}(`IF%%ELSE%`_instr(blocktype, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) = $free_blocktype(blocktype) +++ $free_block(instr_1*{instr_1 <- `instr_1*`}) +++ $free_block(instr_2*{instr_2 <- `instr_2*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:445.1-445.56 - def $free_instr{labelidx : uN}(BR_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:446.1-446.59 - def $free_instr{labelidx : uN}(BR_IF_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:447.1-448.69 - def $free_instr{`labelidx*` : labelidx*, labelidx' : uN}(BR_TABLE_instr(labelidx*{labelidx <- `labelidx*`}, labelidx')) = $free_list($free_labelidx(labelidx)*{labelidx <- `labelidx*`}) +++ $free_labelidx(labelidx') - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:449.1-449.64 - def $free_instr{labelidx : uN}(BR_ON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:450.1-450.68 - def $free_instr{labelidx : uN}(BR_ON_NON_NULL_instr(labelidx)) = $free_labelidx(labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:451.1-452.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:453.1-454.83 - def $free_instr{labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2)) = $free_labelidx(labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:456.1-456.55 - def $free_instr{funcidx : uN}(CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:457.1-457.59 - def $free_instr{typeuse : typeuse}(CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:458.1-459.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 - def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 - def $free_instr{funcidx : uN}(RETURN_CALL_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 - def $free_instr{typeuse : typeuse}(RETURN_CALL_REF_instr(typeuse)) = $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:463.1-464.53 - def $free_instr{tableidx : uN, typeuse : typeuse}(RETURN_CALL_INDIRECT_instr(tableidx, typeuse)) = $free_tableidx(tableidx) +++ $free_typeuse(typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:466.1-466.53 - def $free_instr{tagidx : uN}(THROW_instr(tagidx)) = $free_tagidx(tagidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 - def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 - def $free_instr{blocktype : blocktype, `catch*` : catch*, `instr*` : instr*}(TRY_TABLE_instr(blocktype, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})) = $free_blocktype(blocktype) +++ $free_list($free_catch(catch)*{catch <- `catch*`}) +++ $free_list($free_instr(instr)*{instr <- `instr*`}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 - def $free_instr{numtype : numtype, numlit : num_}(CONST_instr(numtype, numlit)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:472.1-472.60 - def $free_instr{numtype : numtype, unop : unop_}(UNOP_instr(numtype, unop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:473.1-473.62 - def $free_instr{numtype : numtype, binop : binop_}(BINOP_instr(numtype, binop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:474.1-474.64 - def $free_instr{numtype : numtype, testop : testop_}(TESTOP_instr(numtype, testop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:475.1-475.62 - def $free_instr{numtype : numtype, relop : relop_}(RELOP_instr(numtype, relop)) = $free_numtype(numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:476.1-477.55 - def $free_instr{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}(CVTOP_instr(numtype_1, numtype_2, cvtop)) = $free_numtype(numtype_1) +++ $free_numtype(numtype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:479.1-479.64 - def $free_instr{vectype : vectype, veclit : uN}(VCONST_instr(vectype, veclit)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:480.1-480.64 - def $free_instr{vectype : vectype, vvunop : vvunop}(VVUNOP_instr(vectype, vvunop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:481.1-481.66 - def $free_instr{vectype : vectype, vvbinop : vvbinop}(VVBINOP_instr(vectype, vvbinop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:482.1-482.68 - def $free_instr{vectype : vectype, vvternop : vvternop}(VVTERNOP_instr(vectype, vvternop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:483.1-483.68 - def $free_instr{vectype : vectype, vvtestop : vvtestop}(VVTESTOP_instr(vectype, vvtestop)) = $free_vectype(vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:484.1-484.56 - def $free_instr{shape : shape, vunop : vunop_}(VUNOP_instr(shape, vunop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:485.1-485.58 - def $free_instr{shape : shape, vbinop : vbinop_}(VBINOP_instr(shape, vbinop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:486.1-486.60 - def $free_instr{shape : shape, vternop : vternop_}(VTERNOP_instr(shape, vternop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:487.1-487.60 - def $free_instr{shape : shape, vtestop : vtestop_}(VTESTOP_instr(shape, vtestop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:488.1-488.58 - def $free_instr{shape : shape, vrelop : vrelop_}(VRELOP_instr(shape, vrelop)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:489.1-489.64 - def $free_instr{ishape : ishape, vshiftop : vshiftop_}(VSHIFTOP_instr(ishape, vshiftop)) = $free_shape(ishape!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:490.1-490.55 - def $free_instr{ishape : ishape}(VBITMASK_instr(ishape)) = $free_shape(ishape!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:491.1-491.66 - def $free_instr{bshape : bshape, vswizzlop : vswizzlop_}(VSWIZZLOP_instr(bshape, vswizzlop)) = $free_shape(bshape!`%`_bshape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:492.1-492.64 - def $free_instr{bshape : bshape, `laneidx*` : laneidx*}(VSHUFFLE_instr(bshape, laneidx*{laneidx <- `laneidx*`})) = $free_shape(bshape!`%`_bshape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:493.1-494.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}(VEXTUNOP_instr(ishape_1, ishape_2, vextunop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:495.1-496.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:497.1-498.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:499.1-500.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, sx : sx}(VNARROW_instr(ishape_1, ishape_2, sx)) = $free_shape(ishape_1!`%`_ishape.0) +++ $free_shape(ishape_2!`%`_ishape.0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:501.1-502.47 - def $free_instr{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}(VCVTOP_instr(shape_1, shape_2, vcvtop)) = $free_shape(shape_1) +++ $free_shape(shape_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:503.1-503.51 - def $free_instr{shape : shape}(VSPLAT_instr(shape)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:504.1-504.70 - def $free_instr{shape : shape, `sx?` : sx?, laneidx : uN}(VEXTRACT_LANE_instr(shape, sx?{sx <- `sx?`}, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:505.1-505.66 - def $free_instr{shape : shape, laneidx : uN}(VREPLACE_LANE_instr(shape, laneidx)) = $free_shape(shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:507.1-507.62 - def $free_instr{heaptype : heaptype}(`REF.NULL`_instr(heaptype)) = $free_heaptype(heaptype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 - def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 - def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 - def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 - def $free_instr{reftype : reftype}(`REF.TEST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 - def $free_instr{reftype : reftype}(`REF.CAST`_instr(reftype)) = $free_reftype(reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:513.1-513.59 - def $free_instr{funcidx : uN}(`REF.FUNC`_instr(funcidx)) = $free_funcidx(funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 - def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 - def $free_instr{sx : sx}(`I31.GET`_instr(sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 - def $free_instr{typeidx : uN}(`STRUCT.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 - def $free_instr{typeidx : uN}(`STRUCT.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:520.1-520.69 - def $free_instr{`sx?` : sx?, typeidx : uN, u32 : uN}(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:521.1-521.65 - def $free_instr{typeidx : uN, u32 : uN}(`STRUCT.SET`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:523.1-523.60 - def $free_instr{typeidx : uN}(`ARRAY.NEW`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:524.1-524.68 - def $free_instr{typeidx : uN}(`ARRAY.NEW_DEFAULT`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:525.1-525.70 - def $free_instr{typeidx : uN, u32 : uN}(`ARRAY.NEW_FIXED`_instr(typeidx, u32)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:526.1-527.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.NEW_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:528.1-529.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:530.1-530.64 - def $free_instr{`sx?` : sx?, typeidx : uN}(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:531.1-531.60 - def $free_instr{typeidx : uN}(`ARRAY.SET`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 - def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 - def $free_instr{typeidx : uN}(`ARRAY.FILL`_instr(typeidx)) = $free_typeidx(typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 - def $free_instr{typeidx_1 : uN, typeidx_2 : uN}(`ARRAY.COPY`_instr(typeidx_1, typeidx_2)) = $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:536.1-537.51 - def $free_instr{typeidx : uN, dataidx : uN}(`ARRAY.INIT_DATA`_instr(typeidx, dataidx)) = $free_typeidx(typeidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:538.1-539.51 - def $free_instr{typeidx : uN, elemidx : uN}(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx)) = $free_typeidx(typeidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 - def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 - def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 - def $free_instr{localidx : uN}(`LOCAL.GET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 - def $free_instr{localidx : uN}(`LOCAL.SET`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:546.1-546.63 - def $free_instr{localidx : uN}(`LOCAL.TEE`_instr(localidx)) = $free_localidx(localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:548.1-548.67 - def $free_instr{globalidx : uN}(`GLOBAL.GET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:549.1-549.67 - def $free_instr{globalidx : uN}(`GLOBAL.SET`_instr(globalidx)) = $free_globalidx(globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:551.1-551.63 - def $free_instr{tableidx : uN}(`TABLE.GET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:552.1-552.63 - def $free_instr{tableidx : uN}(`TABLE.SET`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:553.1-553.64 - def $free_instr{tableidx : uN}(`TABLE.SIZE`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:554.1-554.64 - def $free_instr{tableidx : uN}(`TABLE.GROW`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:555.1-555.64 - def $free_instr{tableidx : uN}(`TABLE.FILL`_instr(tableidx)) = $free_tableidx(tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:556.1-557.59 - def $free_instr{tableidx_1 : uN, tableidx_2 : uN}(`TABLE.COPY`_instr(tableidx_1, tableidx_2)) = $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:558.1-559.53 - def $free_instr{tableidx : uN, elemidx : uN}(`TABLE.INIT`_instr(tableidx, elemidx)) = $free_tableidx(tableidx) +++ $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:560.1-560.60 - def $free_instr{elemidx : uN}(`ELEM.DROP`_instr(elemidx)) = $free_elemidx(elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:562.1-563.49 - def $free_instr{numtype : numtype, `loadop?` : loadop_?, memidx : uN, memarg : memarg}(LOAD_instr(numtype, loadop?{loadop <- `loadop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:564.1-565.49 - def $free_instr{numtype : numtype, `storeop?` : storeop_?, memidx : uN, memarg : memarg}(STORE_instr(numtype, storeop?{storeop <- `storeop?`}, memidx, memarg)) = $free_numtype(numtype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:566.1-567.49 - def $free_instr{vectype : vectype, `vloadop?` : vloadop_?, memidx : uN, memarg : memarg}(VLOAD_instr(vectype, vloadop?{vloadop <- `vloadop?`}, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:568.1-569.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:570.1-571.49 - def $free_instr{vectype : vectype, memidx : uN, memarg : memarg}(VSTORE_instr(vectype, memidx, memarg)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:572.1-573.49 - def $free_instr{vectype : vectype, sz : sz, memidx : uN, memarg : memarg, laneidx : uN}(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx)) = $free_vectype(vectype) +++ $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:574.1-574.59 - def $free_instr{memidx : uN}(`MEMORY.SIZE`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:575.1-575.59 - def $free_instr{memidx : uN}(`MEMORY.GROW`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:576.1-576.59 - def $free_instr{memidx : uN}(`MEMORY.FILL`_instr(memidx)) = $free_memidx(memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:577.1-578.51 - def $free_instr{memidx_1 : uN, memidx_2 : uN}(`MEMORY.COPY`_instr(memidx_1, memidx_2)) = $free_memidx(memidx_1) +++ $free_memidx(memidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:579.1-580.49 - def $free_instr{memidx : uN, dataidx : uN}(`MEMORY.INIT`_instr(memidx, dataidx)) = $free_memidx(memidx) +++ $free_dataidx(dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:581.1-581.60 - def $free_instr{dataidx : uN}(`DATA.DROP`_instr(dataidx)) = $free_dataidx(dataidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.1-421.31 -def $free_block(instr*) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:589.1-590.47 - def $free_block{`instr*` : instr*}(instr*{instr <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] - -- let{free : free} free = $free_list($free_instr(instr)*{instr <- `instr*`}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{instr : instr, ret_val : free, var_0 : free}: + `%%`(instr, ret_val) + -- wf_instr: `%`(instr) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_instr: `%%`(instr, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_block: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_expr(expr : expr) : free +relation fun_free_expr: `%%`(expr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_expr_case_0{`instr*` : instr*, `var_1*` : free*, var_0 : free}: + `%%`(instr#6*{instr#6 <- `instr*`}, var_0) + -- (fun_free_instr: `%%`(instr, var_1))*{var_1 <- `var_1*`, instr <- `instr*`} + -- if (|`var_1*`| = |`instr*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(expr : expr, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_expr{`instr*` : instr*}(instr*{instr <- `instr*`}) = $free_list($free_instr(instr)*{instr <- `instr*`}) + rule free_expr_is_wf_0{expr : expr, ret_val : free, var_0 : free}: + `%%`(expr, ret_val) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_expr: `%%`(expr, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = @@ -4694,19 +6568,55 @@ relation wf_module: `%`(module) -- (wf_start: `%`(start))?{start <- `start?`} ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_type(type : type) : free +relation fun_free_type: `%%`(type, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_type_case_0{rectype : rectype, var_0 : free}: + `%%`(TYPE_type(rectype), var_0) + -- fun_free_rectype: `%%`(rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{type : type, ret_val : free, var_0 : free}: + `%%`(type, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_type: `%%`(type, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_tag: `%%`(tag, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_type{rectype : rectype}(TYPE_type(rectype)) = $free_rectype(rectype) + rule fun_free_tag_case_0{tagtype : typeuse, var_0 : free}: + `%%`(TAG_tag(tagtype), var_0) + -- fun_free_tagtype: `%%`(tagtype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_tag(tag : tag) : free +relation free_tag_is_wf: `%%`(tag : tag, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) + rule free_tag_is_wf_0{tag : tag, ret_val : free, var_0 : free}: + `%%`(tag, ret_val) + -- wf_tag: `%`(tag) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tag: `%%`(tag, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_global(global : global) : free +relation fun_free_global: `%%`(global, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_global{globaltype : globaltype, expr : instr*}(GLOBAL_global(globaltype, expr)) = $free_globaltype(globaltype) +++ $free_expr(expr) + rule fun_free_global_case_0{globaltype : globaltype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(GLOBAL_global(globaltype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_globaltype: `%%`(globaltype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_global_is_wf: `%%`(global : global, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_global_is_wf_0{global : global, ret_val : free, var_0 : free}: + `%%`(global, ret_val) + -- wf_global: `%`(global) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_global: `%%`(global, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(mem : mem) : free @@ -4714,93 +6624,270 @@ def $free_mem(mem : mem) : free def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free +relation free_mem_is_wf: `%%`(mem : mem, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_table{tabletype : tabletype, expr : instr*}(TABLE_table(tabletype, expr)) = $free_tabletype(tabletype) +++ $free_expr(expr) + rule free_mem_is_wf_0{mem : mem, ret_val : free}: + `%%`(mem, ret_val) + -- wf_mem: `%`(mem) + -- if (ret_val = $free_mem(mem)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_local(local : local) : free +relation fun_free_table: `%%`(table, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + rule fun_free_table_case_0{tabletype : tabletype, expr : instr*, var_1 : free, var_0 : free}: + `%%`(TABLE_table(tabletype, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tabletype: `%%`(tabletype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_func(func : func) : free +relation free_table_is_wf: `%%`(table : table, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_func{typeidx : uN, `local*` : local*, expr : instr*}(FUNC_func(typeidx, local*{local <- `local*`}, expr)) = $free_typeidx(typeidx) +++ $free_list($free_local(local)*{local <- `local*`}) +++ $free_block(expr)[LOCALS_free = []] + rule free_table_is_wf_0{table : table, ret_val : free, var_0 : free}: + `%%`(table, ret_val) + -- wf_table: `%`(table) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_table: `%%`(table, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free +relation fun_free_local: `%%`(local, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode{memidx : uN, expr : instr*}(ACTIVE_datamode(memidx, expr)) = $free_memidx(memidx) +++ $free_expr(expr) + rule fun_free_local_case_0{t : valtype, var_0 : free}: + `%%`(LOCAL_local(t), var_0) + -- fun_free_valtype: `%%`(t, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(local : local, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule free_local_is_wf_0{local : local, ret_val : free, var_0 : free}: + `%%`(local, ret_val) + -- wf_local: `%`(local) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_local: `%%`(local, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(data : data) : free +relation fun_free_func: `%%`(func, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_data{`byte*` : byte*, datamode : datamode}(DATA_data(byte*{byte <- `byte*`}, datamode)) = $free_datamode(datamode) + rule fun_free_func_case_0{typeidx : uN, `local*` : local*, expr : instr*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), $free_typeidx(typeidx) +++ var_0 +++ var_2[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_2) + -- (fun_free_local: `%%`(local, var_1))*{var_1 <- `var_1*`, local <- `local*`} + -- if (|`var_1*`| = |`local*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elemmode(elemmode : elemmode) : free +relation free_func_is_wf: `%%`(func : func, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode{tableidx : uN, expr : instr*}(ACTIVE_elemmode(tableidx, expr)) = $free_tableidx(tableidx) +++ $free_expr(expr) + rule free_func_is_wf_0{func : func, ret_val : free, var_0 : free}: + `%%`(func, ret_val) + -- wf_func: `%`(func) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_func: `%%`(func, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_datamode: `%%`(datamode, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_datamode_case_0{memidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), $free_memidx(memidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_datamode_case_1: + `%%`(PASSIVE_datamode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elem(elem : elem) : free +relation free_datamode_is_wf: `%%`(datamode : datamode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elem{reftype : reftype, `expr*` : expr*, elemmode : elemmode}(ELEM_elem(reftype, expr*{expr <- `expr*`}, elemmode)) = $free_reftype(reftype) +++ $free_list($free_expr(expr)*{expr <- `expr*`}) +++ $free_elemmode(elemmode) + rule free_datamode_is_wf_0{datamode : datamode, ret_val : free, var_0 : free}: + `%%`(datamode, ret_val) + -- wf_datamode: `%`(datamode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_datamode: `%%`(datamode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_start(start : start) : free +relation fun_free_data: `%%`(data, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) + rule fun_free_data_case_0{`byte*` : byte*, datamode : datamode, var_0 : free}: + `%%`(DATA_data(byte#1*{byte#1 <- `byte*`}, datamode), var_0) + -- fun_free_datamode: `%%`(datamode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free +relation free_data_is_wf: `%%`(data : data, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_import{name_1 : name, name_2 : name, externtype : externtype}(IMPORT_import(name_1, name_2, externtype)) = $free_externtype(externtype) + rule free_data_is_wf_0{data : data, ret_val : free, var_0 : free}: + `%%`(data, ret_val) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_data: `%%`(data, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_export(export : export) : free +relation fun_free_elemmode: `%%`(elemmode, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) + rule fun_free_elemmode_case_0{tableidx : uN, expr : instr*, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), $free_tableidx(tableidx) +++ var_0) + -- fun_free_expr: `%%`(expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_1: + `%%`(PASSIVE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_2: + `%%`(DECLARE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free +relation free_elemmode_is_wf: `%%`(elemmode : elemmode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_module{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*}(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) = $free_list($free_type(type)*{type <- `type*`}) +++ $free_list($free_tag(tag)*{tag <- `tag*`}) +++ $free_list($free_global(global)*{global <- `global*`}) +++ $free_list($free_mem(mem)*{mem <- `mem*`}) +++ $free_list($free_table(table)*{table <- `table*`}) +++ $free_list($free_func(func)*{func <- `func*`}) +++ $free_list($free_data(data)*{data <- `data*`}) +++ $free_list($free_elem(elem)*{elem <- `elem*`}) +++ $free_opt($free_start(start)?{start <- `start?`}) +++ $free_list($free_import(import)*{import <- `import*`}) +++ $free_list($free_export(export)*{export <- `export*`}) + rule free_elemmode_is_wf_0{elemmode : elemmode, ret_val : free, var_0 : free}: + `%%`(elemmode, ret_val) + -- wf_elemmode: `%`(elemmode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemmode: `%%`(elemmode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $funcidx_module(module : module) : funcidx* +relation fun_free_elem: `%%`(elem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $funcidx_module{module : module}(module) = $free_module(module).FUNCS_free + rule fun_free_elem_case_0{reftype : reftype, `expr*` : expr*, elemmode : elemmode, var_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(ELEM_elem(reftype, expr#358*{expr#358 <- `expr*`}, elemmode), var_0 +++ var_1 +++ var_3) + -- fun_free_elemmode: `%%`(elemmode, var_3) + -- (fun_free_expr: `%%`(expr, var_2))*{var_2 <- `var_2*`, expr <- `expr*`} + -- if (|`var_2*`| = |`expr*`|) + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_reftype: `%%`(reftype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $dataidx_funcs(func*) : dataidx* +relation free_elem_is_wf: `%%`(elem : elem, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $dataidx_funcs{`func*` : func*}(func*{func <- `func*`}) = $free_list($free_func(func)*{func <- `func*`}).DATAS_free + rule free_elem_is_wf_0{elem : elem, ret_val : free, var_0 : free}: + `%%`(elem, ret_val) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elem: `%%`(elem, var_0) -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax init = - | SET - | UNSET +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +def $free_start(start : start) : free + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -syntax localtype = - | `%%`(init : init, valtype : valtype) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_start_is_wf: `%%`(start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{start : start, ret_val : free}: + `%%`(start, ret_val) + -- wf_start: `%`(start) + -- if (ret_val = $free_start(start)) + -- wf_free: `%`(ret_val) -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -relation wf_localtype: `%`(localtype) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - rule localtype_case_0{init : init, valtype : valtype}: - `%`(`%%`_localtype(init, valtype)) +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_import: `%%`(import, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_import_case_0{name_1 : name, name_2 : name, externtype : externtype, var_0 : free}: + `%%`(IMPORT_import(name_1, name_2, externtype), var_0) + -- fun_free_externtype: `%%`(externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{import : import, ret_val : free, var_0 : free}: + `%%`(import, ret_val) + -- wf_import: `%`(import) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_import: `%%`(import, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +def $free_export(export : export) : free + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + def $free_export{name : name, externidx : externidx}(EXPORT_export(name, externidx)) = $free_externidx(externidx) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_export_is_wf: `%%`(export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{export : export, ret_val : free}: + `%%`(export, ret_val) + -- wf_export: `%`(export) + -- if (ret_val = $free_export(export)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_module: `%%`(module, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_module_case_0{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_17 : free, `var_16*` : free*, var_15 : free, `var_14*` : free*, var_13 : free, `var_12*` : free*, var_11 : free, `var_10*` : free*, var_9 : free, `var_8*` : free*, var_7 : free, var_6 : free, `var_5*` : free*, var_4 : free, `var_3*` : free*, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(MODULE_module(`%`_list(type#1*{type#1 <- `type*`}), `%`_list(import#1*{import#1 <- `import*`}), `%`_list(tag#1*{tag#1 <- `tag*`}), `%`_list(global#1*{global#1 <- `global*`}), `%`_list(mem#1*{mem#1 <- `mem*`}), `%`_list(table#1*{table#1 <- `table*`}), `%`_list(func#1*{func#1 <- `func*`}), `%`_list(data#1*{data#1 <- `data*`}), `%`_list(elem#1*{elem#1 <- `elem*`}), start#1?{start#1 <- `start?`}, `%`_list(export#1*{export#1 <- `export*`})), var_0 +++ var_2 +++ var_4 +++ var_6 +++ var_7 +++ var_9 +++ var_11 +++ var_13 +++ $free_opt($free_start(start)?{start <- `start?`}) +++ var_15 +++ var_17) + -- fun_free_list: `%%`($free_export(export)*{export <- `export*`}, var_17) + -- (fun_free_import: `%%`(import, var_16))*{var_16 <- `var_16*`, import <- `import*`} + -- if (|`var_16*`| = |`import*`|) + -- fun_free_list: `%%`(var_16*{var_16 <- `var_16*`}, var_15) + -- (fun_free_elem: `%%`(elem, var_14))*{var_14 <- `var_14*`, elem <- `elem*`} + -- if (|`var_14*`| = |`elem*`|) + -- fun_free_list: `%%`(var_14*{var_14 <- `var_14*`}, var_13) + -- (fun_free_data: `%%`(data, var_12))*{var_12 <- `var_12*`, data <- `data*`} + -- if (|`var_12*`| = |`data*`|) + -- fun_free_list: `%%`(var_12*{var_12 <- `var_12*`}, var_11) + -- (fun_free_func: `%%`(func, var_10))*{var_10 <- `var_10*`, func <- `func*`} + -- if (|`var_10*`| = |`func*`|) + -- fun_free_list: `%%`(var_10*{var_10 <- `var_10*`}, var_9) + -- (fun_free_table: `%%`(table, var_8))*{var_8 <- `var_8*`, table <- `table*`} + -- if (|`var_8*`| = |`table*`|) + -- fun_free_list: `%%`(var_8*{var_8 <- `var_8*`}, var_7) + -- fun_free_list: `%%`($free_mem(mem)*{mem <- `mem*`}, var_6) + -- (fun_free_global: `%%`(global, var_5))*{var_5 <- `var_5*`, global <- `global*`} + -- if (|`var_5*`| = |`global*`|) + -- fun_free_list: `%%`(var_5*{var_5 <- `var_5*`}, var_4) + -- (fun_free_tag: `%%`(tag, var_3))*{var_3 <- `var_3*`, tag <- `tag*`} + -- if (|`var_3*`| = |`tag*`|) + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- (fun_free_type: `%%`(type, var_1))*{var_1 <- `var_1*`, type <- `type*`} + -- if (|`var_1*`| = |`type*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(module : module, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_module_is_wf_0{module : module, ret_val : free, var_0 : free}: + `%%`(module, ret_val) + -- wf_module: `%`(module) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_module: `%%`(module, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_funcidx_module: `%%`(module, funcidx*) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_funcidx_module_case_0{module : module, var_0 : free}: + `%%`(module, var_0.FUNCS_free) + -- fun_free_module: `%%`(module, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_dataidx_funcs: `%%`(func*, dataidx*) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_dataidx_funcs_case_0{`func*` : func*, `var_1*` : free*, var_0 : free}: + `%%`(func#2*{func#2 <- `func*`}, var_0.DATAS_free) + -- (fun_free_func: `%%`(func, var_1))*{var_1 <- `var_1*`, func <- `func*`} + -- if (|`var_1*`| = |`func*`|) + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +syntax init = + | SET + | UNSET + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +syntax localtype = + | `%%`(init : init, valtype : valtype) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation wf_localtype: `%`(localtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule localtype_case_0{init : init, valtype : valtype}: + `%`(`%%`_localtype(init, valtype)) -- wf_valtype: `%`(valtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -4846,60 +6933,147 @@ relation wf_context: `%`(context) -- (wf_uN: `%%`(32, var_11))*{var_11 <- var_11} -- (wf_subtype: `%`(var_12))*{var_12 <- var_12} +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_with_locals_before_fun_with_locals_case_2: `%%%`(context, localidx*, localtype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_0{C : context}: + `%%%`(C, [], []) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.1-49.158 -def $with_locals(context : context, localidx*, localtype*) : context? - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:51.1-51.34 - def $with_locals{C : context}(C, [], []) = ?(C) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:52.1-52.90 - def $with_locals{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*}(C, [x_1] ++ x*{x <- `x*`}, [lct_1] ++ lct*{lct <- `lct*`}) = $with_locals(C[LOCALS_context[x_1!`%`_uN.0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}) - def $with_locals{x0 : context, x1 : localidx*, x2 : localtype*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation fun_with_locals: `%%%%`(context, localidx*, localtype*, context?) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_0{C : context}: + `%%%%`(C, [], [], ?(C)) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_1{C : context, x_1 : uN, `x*` : idx*, lct_1 : localtype, `lct*` : localtype*, var_0 : context?}: + `%%%%`(C, [x_1] ++ x#1*{x#1 <- `x*`}, [lct_1] ++ lct#1*{lct#1 <- `lct*`}, var_0) + -- fun_with_locals: `%%%%`(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x*{x <- `x*`}, lct*{lct <- `lct*`}, var_0) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_2{x0 : context, x1 : localidx*, x2 : localtype*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_with_locals_before_fun_with_locals_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context, var_2 : context?}: + `%%%%`(context, var_0, var_1, ret_val) + -- wf_context: `%`(context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_context: `%`(ret_val) + -- fun_with_locals: `%%%%`(context, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 -def $clos_deftypes(deftype*) : deftype* - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 - def $clos_deftypes([]) = [] - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:72.1-72.101 - def $clos_deftypes{`dt*` : deftype*, dt_n : deftype}(dt*{dt <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, (dt' : deftype <: typeuse)*{dt' <- `dt'*`})] - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(dt*{dt <- `dt*`}) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 +relation fun_clos_deftypes: `%%`(deftype*, deftype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- let{`dt'*` : deftype*} dt'#1*{dt'#1 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_valtype(context : context, valtype : valtype) : valtype +relation fun_clos_valtype: `%%%`(context, valtype, valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_valtype_case_0{C : context, t : valtype, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- let{`dt*` : deftype*} dt#4*{dt#4 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(context : context, valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{context : context, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(context, valtype, ret_val) + -- wf_context: `%`(context) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_clos_valtype: `%%%`(context, valtype, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_deftype: `%%%`(context, deftype, deftype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_deftype_case_0{C : context, dt : deftype, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- let{`dt'*` : deftype*} dt'#2*{dt'#2 <- `dt'*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- let{`dt*` : deftype*} dt#5*{dt#5 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype}(C, dt) = $subst_all_deftype(dt, (dt' : deftype <: typeuse)*{dt' <- `dt'*`}) - -- let{`dt'*` : deftype*} dt'*{dt' <- `dt'*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_externtype_case_0{C : context, xt : externtype, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- let{`dt*` : deftype*} dt#6*{dt#6 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype +relation clos_externtype_is_wf: `%%%`(context : context, externtype : externtype, ret_val : externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse}(C, jt) = $subst_all_tagtype(jt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_externtype_is_wf_0{context : context, externtype : externtype, ret_val : externtype, var_0 : externtype}: + `%%%`(context, externtype, ret_val) + -- wf_context: `%`(context) + -- wf_externtype: `%`(externtype) + -- if (ret_val = var_0) + -- wf_externtype: `%`(ret_val) + -- fun_clos_externtype: `%%%`(context, externtype, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- let{`dt*` : deftype*} dt#7*{dt#7 <- `dt*`} = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype +relation clos_moduletype_is_wf: `%%%`(context : context, moduletype : moduletype, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context) + rule clos_moduletype_is_wf_0{context : context, moduletype : moduletype, ret_val : moduletype, var_0 : moduletype}: + `%%%`(context, moduletype, ret_val) + -- wf_context: `%`(context) + -- wf_moduletype: `%`(moduletype) + -- if (ret_val = var_0) + -- wf_moduletype: `%`(ret_val) + -- fun_clos_moduletype: `%%%`(context, moduletype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -4943,10 +7117,12 @@ relation Numtype_sub: `%|-%<:%`(context, numtype, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Expand: `%~~%`(deftype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*}: + rule _{deftype : deftype, comptype : comptype, `final?` : final?, `typeuse*` : typeuse*, var_0 : subtype}: `%~~%`(deftype, comptype) - -- if ($unrolldt(deftype) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- fun_unrolldt: `%%`(deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -4963,13 +7139,33 @@ def $before(typeuse : typeuse, nat : nat) : bool def $before{typeuse : typeuse, i : nat}(typeuse, i) = true ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $unrollht_(context : context, heaptype : heaptype) : subtype +relation fun_unrollht_: `%%%`(context, heaptype, subtype) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule fun_unrollht__case_0{rectype : rectype, n : n, C : context, var_0 : subtype}: + `%%%`(C, _DEF_heaptype(rectype, n), var_0) + -- fun_unrolldt: `%%`(_DEF_deftype(rectype, n), var_0) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, deftype : deftype}(C, (deftype : deftype <: heaptype)) = $unrolldt(deftype) + rule fun_unrollht__case_1{C : context, typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(typeidx), var_0) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(typeidx).0], var_0) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, typeidx : uN}(C, _IDX_heaptype(typeidx)) = $unrolldt(C.TYPES_context[typeidx!`%`_uN.0]) + rule fun_unrollht__case_2{C : context, i : nat}: + `%%%`(C, REC_heaptype(i), C.RECS_context[i]) + -- if (i < |C.RECS_context|) + +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(context : context, heaptype : heaptype, ret_val : subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + rule unrollht__is_wf_0{context : context, heaptype : heaptype, ret_val : subtype, var_0 : subtype}: + `%%%`(context, heaptype, ret_val) + -- wf_context: `%`(context) + -- wf_heaptype: `%`(heaptype) + -- if (ret_val = var_0) + -- wf_subtype: `%`(ret_val) + -- fun_unrollht_: `%%%`(context, heaptype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -4978,12 +7174,12 @@ rec { relation Heaptype_ok: `%|-%:OK`(context, heaptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:20.1-21.24 rule abs{C : context, absheaptype : absheaptype}: - `%|-%:OK`(C, (absheaptype : absheaptype <: heaptype)) + `%|-%:OK`(C, $heaptype_absheaptype(absheaptype)) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:23.1-25.35 rule typeuse{C : context, typeuse : typeuse}: - `%|-%:OK`(C, (typeuse : typeuse <: heaptype)) + `%|-%:OK`(C, $heaptype_typeuse(typeuse)) -- Typeuse_ok: `%|-%:OK`(C, typeuse) -- wf_context: `%`(C) -- wf_typeuse: `%`(typeuse) @@ -5007,19 +7203,19 @@ relation Reftype_ok: `%|-%:OK`(context, reftype) relation Valtype_ok: `%|-%:OK`(context, valtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:34.1-36.35 rule num{C : context, numtype : numtype}: - `%|-%:OK`(C, (numtype : numtype <: valtype)) + `%|-%:OK`(C, $valtype_numtype(numtype)) -- Numtype_ok: `%|-%:OK`(C, numtype) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:38.1-40.35 rule vec{C : context, vectype : vectype}: - `%|-%:OK`(C, (vectype : vectype <: valtype)) + `%|-%:OK`(C, $valtype_vectype(vectype)) -- Vectype_ok: `%|-%:OK`(C, vectype) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:42.1-44.35 rule ref{C : context, reftype : reftype}: - `%|-%:OK`(C, (reftype : reftype <: valtype)) + `%|-%:OK`(C, $valtype_reftype(reftype)) -- Reftype_ok: `%|-%:OK`(C, reftype) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype) @@ -5035,7 +7231,8 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(typeidx)) - -- if (C.TYPES_context[typeidx!`%`_uN.0] = dt) + -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5043,13 +7240,14 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) -- if (C.RECS_context[i] = st) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 rule deftype{C : context, deftype : deftype}: - `%|-%:OK`(C, (deftype : deftype <: typeuse)) + `%|-%:OK`(C, $typeuse_deftype(deftype)) -- Deftype_ok: `%|-%:OK`(C, deftype) -- wf_context: `%`(C) @@ -5075,14 +7273,14 @@ relation Fieldtype_ok: `%|-%:OK`(context, fieldtype) relation Storagetype_ok: `%|-%:OK`(context, storagetype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:122.1-124.35 rule val{C : context, valtype : valtype}: - `%|-%:OK`(C, (valtype : valtype <: storagetype)) + `%|-%:OK`(C, $storagetype_valtype(valtype)) -- Valtype_ok: `%|-%:OK`(C, valtype) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:126.1-128.37 rule pack{C : context, packtype : packtype}: - `%|-%:OK`(C, (packtype : packtype <: storagetype)) + `%|-%:OK`(C, $storagetype_packtype(packtype)) -- Packtype_ok: `%|-%:OK`(C, packtype) -- wf_context: `%`(C) @@ -5113,17 +7311,23 @@ relation Comptype_ok: `%|-%:OK`(context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:97.1-97.126 relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:167.1-176.49 - rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**}: + rule _{C : context, `typeuse*` : typeuse*, comptype : comptype, i : nat, `comptype'*` : comptype*, `typeuse'**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} - -- (if ($unrollht_(C, (typeuse : typeuse <: heaptype)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} + -- (if (var_0 = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`typeuse'**`|) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- if (|`comptype'*`| = |`typeuse'**`|) + -- (fun_unrollht_: `%%%`(C, $heaptype_typeuse(typeuse), var_0))*{var_0 <- `var_0*`, typeuse <- `typeuse*`} + -- if (|`var_0*`| = |`typeuse*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) @@ -5151,6 +7355,7 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) -- if (i < n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- if (n = |`subtype*`|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) @@ -5158,6 +7363,7 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) rule struct{C : context, `ft_1*` : fieldtype*, `ft'_1*` : fieldtype*, `ft_2*` : fieldtype*}: `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`})), STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} + -- if (|`ft_1*`| = |`ft_2*`|) -- wf_context: `%`(C) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1*{ft_1 <- `ft_1*`} ++ ft'_1*{ft'_1 <- `ft'_1*`}))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_2*{ft_2 <- `ft_2*`}))) @@ -5182,18 +7388,23 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:103.1-103.107 relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:195.1-197.66 - rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype}: + rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype, var_1 : deftype, var_0 : deftype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) -- wf_context: `%`(C) + -- fun_clos_deftype: `%%%`(C, deftype_2, var_1) + -- fun_clos_deftype: `%%%`(C, deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:199.1-202.49 - rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat}: + rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, `final?` : final?, `typeuse*` : typeuse*, ct : comptype, i : nat, var_0 : subtype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($unrolldt(deftype_1) = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) + -- if (var_0 = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[i]), $heaptype_deftype(deftype_2)) + -- if (i < |typeuse*{typeuse <- `typeuse*`}|) -- wf_context: `%`(C) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- fun_unrolldt: `%%`(deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) @@ -5244,7 +7455,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:41.1-43.42 rule struct{C : context, deftype : deftype, `fieldtype*` : fieldtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), STRUCT_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), STRUCT_heaptype) -- Expand: `%~~%`(deftype, STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) -- wf_context: `%`(C) -- wf_heaptype: `%`(STRUCT_heaptype) @@ -5252,7 +7463,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:45.1-47.40 rule array{C : context, deftype : deftype, fieldtype : fieldtype}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), ARRAY_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), ARRAY_heaptype) -- Expand: `%~~%`(deftype, ARRAY_comptype(fieldtype)) -- wf_context: `%`(C) -- wf_heaptype: `%`(ARRAY_heaptype) @@ -5260,7 +7471,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:49.1-51.42 rule func{C : context, deftype : deftype, `t_1*` : valtype*, `t_2*` : valtype*}: - `%|-%<:%`(C, (deftype : deftype <: heaptype), FUNC_heaptype) + `%|-%<:%`(C, $heaptype_deftype(deftype), FUNC_heaptype) -- Expand: `%~~%`(deftype, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_heaptype: `%`(FUNC_heaptype) @@ -5268,14 +7479,15 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:53.1-55.46 rule def{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: heaptype), (deftype_2 : deftype <: heaptype)) + `%|-%<:%`(C, $heaptype_deftype(deftype_1), $heaptype_deftype(deftype_2)) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule `typeidx-l`{C : context, typeidx : typeidx, heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(typeidx), heaptype) - -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[typeidx!`%`_uN.0] : deftype <: heaptype), heaptype) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) @@ -5283,7 +7495,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: `%|-%<:%`(C, heaptype, _IDX_heaptype(typeidx)) - -- Heaptype_sub: `%|-%<:%`(C, heaptype, (C.TYPES_context[typeidx!`%`_uN.0] : deftype <: heaptype)) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0])) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) @@ -5292,6 +7505,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) @@ -5301,6 +7515,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) rule `rec-array`{C : context, i : n, `final?` : final?, fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) @@ -5310,6 +7525,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) rule `rec-func`{C : context, i : n, `final?` : final?, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(FUNC_heaptype) @@ -5317,11 +7533,13 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule `rec-sub`{C : context, i : n, `typeuse*` : typeuse*, j : nat, `final?` : final?, ct : comptype}: - `%|-%<:%`(C, REC_heaptype(i), (typeuse*{typeuse <- `typeuse*`}[j] : typeuse <: heaptype)) + `%|-%<:%`(C, REC_heaptype(i), $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[j])) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (j < |typeuse*{typeuse <- `typeuse*`}|) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 rule none{C : context, heaptype : heaptype}: @@ -5396,19 +7614,19 @@ relation Reftype_sub: `%|-%<:%`(context, reftype, reftype) relation Valtype_sub: `%|-%<:%`(context, valtype, valtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:114.1-116.46 rule num{C : context, numtype_1 : numtype, numtype_2 : numtype}: - `%|-%<:%`(C, (numtype_1 : numtype <: valtype), (numtype_2 : numtype <: valtype)) + `%|-%<:%`(C, $valtype_numtype(numtype_1), $valtype_numtype(numtype_2)) -- Numtype_sub: `%|-%<:%`(C, numtype_1, numtype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:118.1-120.46 rule vec{C : context, vectype_1 : vectype, vectype_2 : vectype}: - `%|-%<:%`(C, (vectype_1 : vectype <: valtype), (vectype_2 : vectype <: valtype)) + `%|-%<:%`(C, $valtype_vectype(vectype_1), $valtype_vectype(vectype_2)) -- Vectype_sub: `%|-%<:%`(C, vectype_1, vectype_2) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:122.1-124.46 rule ref{C : context, reftype_1 : reftype, reftype_2 : reftype}: - `%|-%<:%`(C, (reftype_1 : reftype <: valtype), (reftype_2 : reftype <: valtype)) + `%|-%<:%`(C, $valtype_reftype(reftype_1), $valtype_reftype(reftype_2)) -- Reftype_sub: `%|-%<:%`(C, reftype_1, reftype_2) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype_1) @@ -5427,6 +7645,7 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) rule _{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%<:%`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (|`t_1*`| = |`t_2*`|) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} -- (wf_valtype: `%`(t_2))*{t_2 <- `t_2*`} @@ -5435,7 +7654,7 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:162.1-164.46 rule val{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, (valtype_1 : valtype <: storagetype), (valtype_2 : valtype <: storagetype)) + `%|-%<:%`(C, $storagetype_valtype(valtype_1), $storagetype_valtype(valtype_2)) -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype_1) @@ -5443,7 +7662,7 @@ relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:166.1-168.49 rule pack{C : context, packtype_1 : packtype, packtype_2 : packtype}: - `%|-%<:%`(C, (packtype_1 : packtype <: storagetype), (packtype_2 : packtype <: storagetype)) + `%|-%<:%`(C, $storagetype_packtype(packtype_1), $storagetype_packtype(packtype_2)) -- Packtype_sub: `%|-%<:%`(C, packtype_1, packtype_2) -- wf_context: `%`(C) @@ -5483,7 +7702,9 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1*{t_1 <- `t_1*`})) -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- (if (C.LOCALS_context[x!`%`_uN.0] = lct))*{lct <- `lct*`, x <- `x*`} + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- `lct*`, x <- `x*`} + -- if (|`lct*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- `lct*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x*{x <- `x*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -5492,7 +7713,7 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule deftype{deftype : deftype, C : context, comptype : comptype}: - `%~~_%%`((deftype : deftype <: typeuse), C, comptype) + `%~~_%%`($typeuse_deftype(deftype), C, comptype) -- Expand: `%~~%`(deftype, comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) @@ -5500,7 +7721,8 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) - -- Expand: `%~~%`(C.TYPES_context[typeidx!`%`_uN.0], comptype) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) @@ -5519,17 +7741,24 @@ relation wf_oktypeidx: `%`(oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**}: + rule _{C : context, `x*` : idx*, comptype : comptype, x_0 : idx, `comptype'*` : comptype*, `yy**` : typeuse**, `var_0*` : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) -- if (|x*{x <- `x*`}| <= 1) - -- (if (x!`%`_uN.0 < x_0!`%`_uN.0))*{x <- `x*`} - -- (if ($unrolldt(C.TYPES_context[x!`%`_uN.0]) = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, x <- `x*`, `yy*` <- `yy**`} + -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} + -- (if (var_0 = SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{var_0 <- `var_0*`, comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`yy**`|) -- Comptype_ok: `%|-%:OK`(C, comptype) -- (Comptype_sub: `%|-%<:%`(C, comptype, comptype'))*{comptype' <- `comptype'*`} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- `var_0*`} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- if (|`comptype'*`| = |`yy**`|) + -- (fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(x).0], var_0))*{var_0 <- `var_0*`, x <- `x*`} + -- if (|`var_0*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5546,12 +7775,12 @@ relation Rectype_ok: `%|-%:%`(context, rectype, oktypeidx) rule cons{C : context, subtype_1 : subtype, `subtype*` : subtype*, x : idx}: `%|-%:%`(C, REC_rectype(`%`_list([subtype_1] ++ subtype*{subtype <- `subtype*`})), OK_oktypeidx(x)) -- Subtype_ok: `%|-%:%`(C, subtype_1, OK_oktypeidx(x)) - -- Rectype_ok: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypeidx(`%`_typeidx((x!`%`_uN.0 + 1)))) + -- Rectype_ok: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypeidx(`%`_typeidx(($proj_uN_0(x).0 + 1)))) -- wf_context: `%`(C) -- wf_subtype: `%`(subtype_1) -- (wf_subtype: `%`(subtype))*{subtype <- `subtype*`} -- wf_oktypeidx: `%`(OK_oktypeidx(x)) - -- wf_oktypeidx: `%`(OK_oktypeidx(`%`_typeidx((x!`%`_uN.0 + 1)))) + -- wf_oktypeidx: `%`(OK_oktypeidx(`%`_typeidx(($proj_uN_0(x).0 + 1)))) } ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5589,7 +7818,7 @@ relation Memtype_ok: `%|-%:OK`(context, memtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule _{C : context, addrtype : addrtype, limits : limits}: `%|-%:OK`(C, `%%PAGE`_memtype(addrtype, limits)) - -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size((addrtype : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size($numtype_addrtype(addrtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) -- wf_context: `%`(C) -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits)) @@ -5598,7 +7827,7 @@ relation Tabletype_ok: `%|-%:OK`(context, tabletype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule _{C : context, addrtype : addrtype, limits : limits, reftype : reftype}: `%|-%:OK`(C, `%%%`_tabletype(addrtype, limits, reftype)) - -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size((addrtype : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) + -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size($numtype_addrtype(addrtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) -- Reftype_ok: `%|-%:OK`(C, reftype) -- wf_context: `%`(C) -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits, reftype)) @@ -5650,9 +7879,12 @@ relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21*{t_21 <- `t_21*`}), `%`_resulttype(t_11*{t_11 <- `t_11*`})) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12*{t_12 <- `t_12*`}), `%`_resulttype(t_22*{t_22 <- `t_22*`})) -- if (x*{x <- `x*`} = $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})) - -- (if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- `t*`, x <- `x*`} + -- if (|`t*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- `x*`} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- `x*`} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2*{x_2 <- `x_2*`}, x_1*{x_1 <- `x_1*`})} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11*{t_11 <- `t_11*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_12*{t_12 <- `t_12*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21*{t_21 <- `t_21*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_22*{t_22 <- `t_22*`}))) -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} @@ -5680,7 +7912,7 @@ relation Limits_sub: `%|-%<:%`(context, limits, limits) relation Tagtype_sub: `%|-%<:%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule _{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, (deftype_1 : deftype <: typeuse), (deftype_2 : deftype <: typeuse)) + `%|-%<:%`(C, $typeuse_deftype(deftype_1), $typeuse_deftype(deftype_2)) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- Deftype_sub: `%|-%<:%`(C, deftype_2, deftype_1) -- wf_context: `%`(C) @@ -5762,11 +7994,11 @@ relation Externtype_sub: `%|-%<:%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule func{C : context, deftype_1 : deftype, deftype_2 : deftype}: - `%|-%<:%`(C, FUNC_externtype((deftype_1 : deftype <: typeuse)), FUNC_externtype((deftype_2 : deftype <: typeuse))) + `%|-%<:%`(C, FUNC_externtype($typeuse_deftype(deftype_1)), FUNC_externtype($typeuse_deftype(deftype_2))) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- wf_context: `%`(C) - -- wf_externtype: `%`(FUNC_externtype((deftype_1 : deftype <: typeuse))) - -- wf_externtype: `%`(FUNC_externtype((deftype_2 : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_1))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_2))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) @@ -5781,7 +8013,8 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, typeidx : typeidx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, _IDX_blocktype(typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.TYPES_context[typeidx!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(typeidx)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -5792,8 +8025,11 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l!`%`_uN.0]) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -5801,8 +8037,11 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[l!`%`_uN.0]) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -5810,43 +8049,57 @@ relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[l!`%`_uN.0]) + -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[l!`%`_uN.0]) + -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Inn : addrtype}((Inn : addrtype <: valtype)) = ?(?(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(0)))) + def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0))))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Fnn : Fnn}((Fnn : Fnn <: valtype)) = ?(?(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))))) - -- wf_val: `%`(CONST_val((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + def $default_(F32_valtype) = ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{Vnn : vectype}((Vnn : vectype <: valtype)) = ?(?(VCONST_val(Vnn, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(Vnn, `%`_vec_(0))) + def $default_(F64_valtype) = ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{valtype : valtype, ret_val : val?}: + `%%`(valtype, ret_val) + -- wf_valtype: `%`(valtype) + -- if (ret_val = !($default_(valtype))) + -- if ($default_(valtype) =/= ?()) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule _{t : valtype}: `|-%DEFAULTABLE`(t) -- if (!($default_(t)) =/= ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -5854,13 +8107,13 @@ relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) rule _{n : n, m : m, at : addrtype, N : N}: `|-%:%->%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}, at, N) -- if (((2 ^ n) : nat <:> rat) <= ((N : nat <:> rat) / (8 : nat <:> rat))) - -- if (m < (2 ^ $size((at : addrtype <: numtype)))) + -- if (m < (2 ^ $size($numtype_addrtype(at)))) -- wf_memarg: `%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec def $is_packtype(storagetype : storagetype) : bool ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= ($unpack(zt) : valtype <: storagetype)) + def $is_packtype{zt : storagetype}(zt) = (zt =/= $storagetype_valtype($unpack(zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rec { @@ -5903,7 +8156,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) `%|-%:%`(C, SELECT_instr(?()), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) -- Valtype_ok: `%|-%:OK`(C, t) -- Valtype_sub: `%|-%<:%`(C, t, t') - -- if ((t' = (numtype : numtype <: valtype)) \/ (t' = (vectype : vectype <: valtype))) + -- if ((t' = $valtype_numtype(numtype)) \/ (t' = $valtype_vectype(vectype))) -- wf_context: `%`(C) -- wf_valtype: `%`(t') -- wf_instr: `%`(SELECT_instr(?())) @@ -5948,7 +8201,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) + -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_instr(l)) @@ -5958,7 +8212,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, `t*` : valtype*}: `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) + -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t*{t <- `t*`}))) @@ -5966,8 +8221,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, `l*` : labelidx*, l' : labelidx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, BR_TABLE_instr(l*{l <- `l*`}, l'), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l!`%`_uN.0]))*{l <- `l*`} - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[l'!`%`_uN.0]) + -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]))*{l <- `l*`} + -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- `l*`} + -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l').0]) + -- if ($proj_uN_0(l').0 < |C.LABELS_context|) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`} ++ [I32_valtype]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) @@ -5976,7 +8233,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), ht)]))) - -- if (C.LABELS_context[l!`%`_uN.0]!`%`_list.0 = t*{t <- `t*`}) + -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t*{t <- `t*`}) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NULL_instr(l)) @@ -5985,15 +8243,17 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, `t*` : valtype*, ht : heaptype}: `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) + -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t*{t <- `t*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) + `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) @@ -6001,25 +8261,28 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [($diffrt(rt_1, rt_2) : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) - -- if (C.LABELS_context[l!`%`_uN.0] = `%`_resulttype(t*{t <- `t*`} ++ [(rt : reftype <: valtype)])) + `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt)])) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [(rt_1 : reftype <: valtype)]), [], `%`_resulttype(t*{t <- `t*`} ++ [(rt_2 : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_2)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6028,7 +8291,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, `t_1*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6036,13 +8300,15 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, `t_1*` : valtype*, at : addrtype, `t_2*` : valtype*, lim : limits, rt : reftype}: - `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- Expand: `%~~%`(C.TYPES_context[y!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6060,7 +8326,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) @@ -6074,7 +8341,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, `t_3*` : valtype*, `t_1*` : valtype*, `t_4*` : valtype*, `t_2*` : valtype*, `t'_2*` : valtype*}: `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) @@ -6087,17 +8355,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, `t_3*` : valtype*, `t_1*` : valtype*, at : addrtype, `t_4*` : valtype*, lim : limits, rt : reftype, `t_2*` : valtype*, `t'_2*` : valtype*}: - `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) - -- Expand: `%~~%`(C.TYPES_context[y!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(y).0 < |C.TYPES_context|) -- if (C.RETURN_context = ?(`%`_resulttype(t'_2*{t'_2 <- `t'_2*`}))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2*{t_2 <- `t_2*`}), `%`_resulttype(t'_2*{t'_2 <- `t'_2*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) -- wf_context: `%`(C) -- (wf_valtype: `%`(t'_2))*{t'_2 <- `t'_2*`} -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [(at : addrtype <: valtype)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`} ++ t_1*{t_1 <- `t_1*`} ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4*{t_4 <- `t_4*`}))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) @@ -6106,7 +8376,9 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[x!`%`_uN.0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(THROW_instr(x)) @@ -6145,12 +8417,14 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule `ref.func`{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) - -- if (C.FUNCS_context[x!`%`_uN.0] = dt) + `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) + -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (x <- C.REFS_context) + -- if (|C.REFS_context| > 0) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), (dt : deftype <: heaptype))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 rule `ref.i31`{C : context}: @@ -6184,23 +8458,23 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:225.1-229.33 rule `ref.test`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) -- wf_instr: `%`(`REF.TEST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:231.1-235.33 rule `ref.cast`{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) -- wf_instr: `%`(`REF.CAST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt' : reftype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:240.1-241.42 rule `i31.get`{C : context, sx : sx}: @@ -6212,7 +8486,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*}: `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6221,9 +8496,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- `zt*`} -- wf_context: `%`(C) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -6231,8 +8508,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?}: `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (ft*{ft <- `ft*`}[i!`%`_uN.0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(mut?{mut <- `mut?`}, zt)) + -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)) @@ -6243,8 +8522,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*}: `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) - -- if (ft*{ft <- `ft*`}[i!`%`_uN.0] = `%%`_fieldtype(?(MUT_mut), zt)) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (ft*{ft <- `ft*`}[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) + -- if ($proj_uN_0(i).0 < |ft*{ft <- `ft*`}|) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) @@ -6254,7 +8535,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6263,9 +8545,11 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6273,7 +8557,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) @@ -6282,20 +8567,25 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule `array.new_elem`{C : context, x : idx, y : idx, `mut?` : mut?, rt : reftype}: `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) - -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[y!`%`_uN.0], rt) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, (rt : reftype <: storagetype)))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, $storagetype_reftype(rt)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) + -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -6303,7 +8593,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)) @@ -6313,7 +8604,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule `array.set`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) @@ -6329,7 +8621,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule `array.fill`{C : context, x : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) @@ -6338,8 +8631,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule `array.copy`{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, `mut?` : mut?, zt_2 : storagetype}: `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x_1!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- Expand: `%~~%`(C.TYPES_context[x_2!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) + -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) + -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) @@ -6350,8 +8645,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule `array.init_elem`{C : context, x : idx, y : idx, zt : storagetype}: `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- Storagetype_sub: `%|-%<:%`(C, (C.ELEMS_context[y!`%`_uN.0] : reftype <: storagetype), zt) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), zt) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) @@ -6360,10 +8657,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- if (($unpack(zt) = $valtype_numtype(numtype)) \/ ($unpack(zt) = $valtype_vectype(vectype))) + -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) + -- wf_valtype: `%`($unpack(zt)) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) @@ -6387,7 +8687,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule `local.get`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(SET_init, t)) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -6396,7 +8697,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule `local.set`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(init, t)) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) @@ -6405,7 +8707,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule `local.tee`{C : context, x : idx, t : valtype, init : init}: `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- if (C.LOCALS_context[x!`%`_uN.0] = `%%`_localtype(init, t)) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) @@ -6414,7 +8717,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule `global.get`{C : context, x : idx, t : valtype, `mut?` : mut?}: `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -6423,7 +8727,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule `global.set`{C : context, x : idx, t : valtype}: `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(MUT_mut), t)) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) @@ -6431,77 +8736,87 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule `table.get`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule `table.set`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule `table.size`{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: - `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule `table.grow`{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: - `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule `table.fill`{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt)) + `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype) (at : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule `table.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x_1!`%`_uN.0] = `%%%`_tabletype(at_1, lim_1, rt_1)) - -- if (C.TABLES_context[x_2!`%`_uN.0] = `%%%`_tabletype(at_2, lim_2, rt_2)) + `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) + -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) + -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) -- wf_instr: `%`(`TABLE.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at_1, lim_1, rt_1)) -- wf_tabletype: `%`(`%%%`_tabletype(at_2, lim_2, rt_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule `table.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt_1)) - -- if (C.ELEMS_context[y!`%`_uN.0] = rt_2) + `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) -- wf_reftype: `%`(rt_2) -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt_1)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule `elem.drop`{C : context, x : idx, rt : reftype}: `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if (C.ELEMS_context[x!`%`_uN.0] = rt) + -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) + -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) @@ -6509,213 +8824,232 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule `memory.size`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule `memory.grow`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule `memory.fill`{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype (at : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule `memory.copy`{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: - `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x_1!`%`_uN.0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if (C.MEMS_context[x_2!`%`_uN.0] = `%%PAGE`_memtype(at_2, lim_2)) + `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) + -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) + -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) + -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at_1 : addrtype <: valtype) (at_2 : addrtype <: valtype) ($minat(at_1, at_2) : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at_1, lim_1)) -- wf_memtype: `%`(`%%PAGE`_memtype(at_2, lim_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule `memory.init`{C : context, x : idx, y : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- if (C.DATAS_context[y!`%`_uN.0] = OK_datatype) + `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule `data.drop`{C : context, x : idx}: `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if (C.DATAS_context[x!`%`_uN.0] = OK_datatype) + -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) + -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule `load-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule `load-pack`{C : context, Inn : Inn, M : M, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) - -- wf_instr: `%`(LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(Inn : addrtype <: valtype)]))) + -- wf_instr: `%`(LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(M), sx))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(Inn)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule `store-val`{C : context, nt : numtype, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule `store-pack`{C : context, Inn : Inn, M : M, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, M) -- wf_context: `%`(C) - -- wf_instr: `%`(STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (Inn : addrtype <: valtype)]), [], `%`_resulttype([]))) + -- wf_instr: `%`(STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(M)))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(Inn)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule `vload-val`{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule `vload-pack`{C : context, M : M, N : N, sx : sx, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, (M * N)) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule `vload-splat`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule `vload-zero`{C : context, N : N, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- if ((i!`%`_uN.0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) + -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, N : N, x : idx, memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) + `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(memarg, at, N) - -- if ((i!`%`_uN.0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) + -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (N : nat <:> rat))) -- wf_context: `%`(C) -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:520.1-521.33 rule const{C : context, nt : numtype, c_nt : num_}: - `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CONST_instr(nt, c_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:523.1-524.34 rule unop{C : context, nt : numtype, unop_nt : unop_}: - `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(UNOP_instr(nt, unop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:526.1-527.39 rule binop{C : context, nt : numtype, binop_nt : binop_}: - `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr(nt, binop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:529.1-530.39 rule testop{C : context, nt : numtype, testop_nt : testop_}: - `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(TESTOP_instr(nt, testop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:532.1-533.40 rule relop{C : context, nt : numtype, relop_nt : relop_}: - `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(RELOP_instr(nt, relop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt : numtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:535.1-536.44 rule cvtop{C : context, nt_1 : numtype, nt_2 : numtype, cvtop : cvtop__}: - `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) + `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CVTOP_instr(nt_1, nt_2, cvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(nt_2 : numtype <: valtype)]), [], `%`_resulttype([(nt_1 : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:541.1-542.35 rule vconst{C : context, c : vec_}: @@ -6811,33 +9145,36 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:580.1-582.29 rule vshuffle{C : context, sh : bshape, `i*` : laneidx*}: `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- (if (i!`%`_uN.0 < (2 * $dim(sh!`%`_bshape.0)!`%`_dim.0)))*{i <- `i*`} + -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($dim($proj_bshape_0(sh).0)).0)))*{i <- `i*`} -- wf_context: `%`(C) + -- wf_dim: `%`($dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 rule vsplat{C : context, sh : shape}: - `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSPLAT_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:587.1-589.21 rule vextract_lane{C : context, sh : shape, `sx?` : sx?, i : laneidx}: - `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) - -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) + `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 rule vreplace_lane{C : context, sh : shape, i : laneidx}: - `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if (i!`%`_uN.0 < $dim(sh)!`%`_dim.0) + `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:595.1-596.50 rule vextunop{C : context, sh_1 : ishape, sh_2 : ishape, vextunop : vextunop__}: @@ -6883,19 +9220,25 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:617.1-621.82 - rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%|-%:%`(C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if (C.LOCALS_context[x_1!`%`_uN.0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} + -- if (|`init*`| = |`t*`|) + -- if (|`init*`| = |`x_1*`|) + -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} + -- Instrs_ok: `%|-%:%`(!(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- if (var_0 =/= ?()) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 rule sub{C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -6935,7 +9278,9 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) -- if (!($default_(t)) = ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7014,21 +9359,24 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule `global.get`{C : context, x : idx, t : valtype}: `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(), t)) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, Inn : Inn, binop : binop_}: - `%|-%CONST`(C, BINOP_instr((Inn : addrtype <: numtype), binop)) + `%|-%CONST`(C, BINOP_instr($numtype_addrtype(Inn), binop)) -- if (Inn <- [I32_Inn I64_Inn]) + -- if (|[I32_Inn I64_Inn]| > 0) -- if (binop <- [mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]) + -- if (|[mk_binop__0_binop_(Inn, ADD_binop_Inn) mk_binop__0_binop_(Inn, SUB_binop_Inn) mk_binop__0_binop_(Inn, MUL_binop_Inn)]| > 0) -- wf_context: `%`(C) - -- wf_instr: `%`(BINOP_instr((Inn : addrtype <: numtype), binop)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn)) - -- wf_binop_: `%%`((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn)) + -- wf_instr: `%`(BINOP_instr($numtype_addrtype(Inn), binop)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, ADD_binop_Inn)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, SUB_binop_Inn)) + -- wf_binop_: `%%`($numtype_addrtype(Inn), mk_binop__0_binop_(Inn, MUL_binop_Inn)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Expr_const: `%|-%CONST`(context, expr) @@ -7053,23 +9401,26 @@ relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Type_ok: `%|-%:%`(context, type, deftype*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx}: + rule _{C : context, rectype : rectype, `dt*` : deftype*, x : idx, var_0 : deftype*}: `%|-%:%`(C, TYPE_type(rectype), dt*{dt <- `dt*`}) - -- if (x!`%`_uN.0 = |C.TYPES_context|) - -- if (dt*{dt <- `dt*`} = $rolldt(x, rectype)) + -- if ($proj_uN_0(x).0 = |C.TYPES_context|) + -- if (dt*{dt <- `dt*`} = var_0) -- Rectype_ok: `%|-%:%`(C +++ {TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rectype, OK_oktypeidx(x)) -- wf_context: `%`(C) -- wf_context: `%`({TYPES dt*{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_oktypeidx: `%`(OK_oktypeidx(x)) + -- fun_rolldt: `%%%`(x, rectype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Tag_ok: `%|-%:%`(context, tag, tagtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, tagtype : tagtype}: - `%|-%:%`(C, TAG_tag(tagtype), $clos_tagtype(C, tagtype)) + rule _{C : context, tagtype : tagtype, var_0 : tagtype}: + `%|-%:%`(C, TAG_tag(tagtype), var_0) -- Tagtype_ok: `%|-%:OK`(C, tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`(var_0) -- wf_tag: `%`(TAG_tag(tagtype)) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7099,7 +9450,7 @@ relation Table_ok: `%|-%:%`(context, table, tabletype) `%|-%:%`(C, TABLE_table(tabletype, expr), tabletype) -- Tabletype_ok: `%|-%:OK`(C, tabletype) -- if (tabletype = `%%%`_tabletype(at, lim, rt)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (rt : reftype <: valtype)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(rt)) -- wf_context: `%`(C) -- wf_table: `%`(TABLE_table(tabletype, expr)) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) @@ -7126,9 +9477,11 @@ relation Local_ok: `%|-%:%`(context, local, localtype) relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx, `local*` : local*, expr : expr, `t_1*` : valtype*, `t_2*` : valtype*, `lct*` : localtype*}: - `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[x!`%`_uN.0]) - -- Expand: `%~~%`(C.TYPES_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + `%|-%:%`(C, FUNC_func(x, local*{local <- `local*`}, expr), C.TYPES_context[$proj_uN_0(x).0]) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- (Local_ok: `%|-%:%`(C, local, lct))*{lct <- `lct*`, local <- `local*`} + -- if (|`lct*`| = |`local*`|) -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- `t_1*`} ++ lct*{lct <- `lct*`}, LABELS [`%`_resulttype(t_2*{t_2 <- `t_2*`})], RETURN ?(`%`_resulttype(t_2*{t_2 <- `t_2*`})), REFS [], RECS []}, expr, `%`_resulttype(t_2*{t_2 <- `t_2*`})) -- wf_context: `%`(C) -- wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr)) @@ -7146,8 +9499,9 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, expr), OK_datatype) - -- if (C.MEMS_context[x!`%`_uN.0] = `%%PAGE`_memtype(at, lim)) - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) @@ -7180,9 +9534,10 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, expr), rt) - -- if (C.TABLES_context[x!`%`_uN.0] = `%%%`_tabletype(at, lim, rt')) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- Reftype_sub: `%|-%<:%`(C, rt, rt') - -- Expr_ok_const: `%|-%:%CONST`(C, expr, (at : addrtype <: valtype)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) @@ -7194,7 +9549,7 @@ relation Elem_ok: `%|-%:%`(context, elem, elemtype) rule _{C : context, elemtype : elemtype, `expr*` : expr*, elemmode : elemmode}: `%|-%:%`(C, ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode), elemtype) -- Reftype_ok: `%|-%:OK`(C, elemtype) - -- (Expr_ok_const: `%|-%:%CONST`(C, expr, (elemtype : reftype <: valtype)))*{expr <- `expr*`} + -- (Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(elemtype)))*{expr <- `expr*`} -- Elemmode_ok: `%|-%:%`(C, elemmode, elemtype) -- wf_context: `%`(C) -- wf_elem: `%`(ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode)) @@ -7204,7 +9559,8 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule _{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) - -- Expand: `%~~%`(C.FUNCS_context[x!`%`_uN.0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) @@ -7212,18 +9568,21 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Import_ok: `%|-%:%`(context, import, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{C : context, name_1 : name, name_2 : name, xt : externtype}: - `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) + rule _{C : context, name_1 : name, name_2 : name, xt : externtype, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`(var_0) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if (C.TAGS_context[x!`%`_uN.0] = jt) + -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) @@ -7231,7 +9590,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if (C.GLOBALS_context[x!`%`_uN.0] = gt) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) @@ -7239,7 +9599,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if (C.MEMS_context[x!`%`_uN.0] = mt) + -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) @@ -7247,18 +9608,20 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if (C.TABLES_context[x!`%`_uN.0] = tt) + -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype((dt : deftype <: typeuse))) - -- if (C.FUNCS_context[x!`%`_uN.0] = dt) + `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) + -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) - -- wf_externtype: `%`(FUNC_externtype((dt : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Export_ok: `%|-%:%%`(context, export, name, externtype) @@ -7328,39 +9691,55 @@ relation wf_nonfuncs: `%`(nonfuncs) -- (wf_export: `%`(export))*{export <- `export*`} ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -def $funcidx_nonfuncs(nonfuncs : nonfuncs) : funcidx* +relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - def $funcidx_nonfuncs{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*}(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) + rule fun_funcidx_nonfuncs_case_0{`global*` : global*, `mem*` : mem*, `table*` : table*, `elem*` : elem*, `start?` : start?, `export*` : export*, var_0 : funcidx*}: + `%%`(`%%%%%%`_nonfuncs(global#2*{global#2 <- `global*`}, mem#2*{mem#2 <- `mem*`}, table#2*{table#2 <- `table*`}, elem#2*{elem#2 <- `elem*`}, start#2?{start#2 <- `start?`}, export#2*{export#2 <- `export*`}), var_0) + -- fun_funcidx_module: `%%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list([]), `%`_list([]), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*}: - `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), $clos_moduletype(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}))) + rule _{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, C : context, `xt_I*` : externtype*, `xt_E*` : externtype*, `dt'*` : deftype*, C' : context, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt*` : deftype*, `ok*` : datatype*, `rt*` : reftype*, `nm*` : name*, `jt_I*` : tagtype*, `mt_I*` : memtype*, `tt_I*` : tabletype*, `gt_I*` : globaltype*, `dt_I*` : deftype*, `x*` : idx*, var_6 : deftype*, var_5 : tabletype*, var_4 : memtype*, var_3 : globaltype*, var_2 : tagtype*, var_1 : funcidx*, var_0 : moduletype}: + `|-%:%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})), var_0) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type*{type <- `type*`}, dt'*{dt' <- `dt'*`}) -- (Import_ok: `%|-%:%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, import, xt_I))*{import <- `import*`, xt_I <- `xt_I*`} + -- if (|`import*`| = |`xt_I*`|) -- (Tag_ok: `%|-%:%`(C', tag, jt))*{jt <- `jt*`, tag <- `tag*`} + -- if (|`jt*`| = |`tag*`|) -- Globals_ok: `%|-%:%`(C', global*{global <- `global*`}, gt*{gt <- `gt*`}) -- (Mem_ok: `%|-%:%`(C', mem, mt))*{mem <- `mem*`, mt <- `mt*`} + -- if (|`mem*`| = |`mt*`|) -- (Table_ok: `%|-%:%`(C', table, tt))*{table <- `table*`, tt <- `tt*`} + -- if (|`table*`| = |`tt*`|) -- (Func_ok: `%|-%:%`(C, func, dt))*{dt <- `dt*`, func <- `func*`} + -- if (|`dt*`| = |`func*`|) -- (Data_ok: `%|-%:%`(C, data, ok))*{data <- `data*`, ok <- `ok*`} + -- if (|`data*`| = |`ok*`|) -- (Elem_ok: `%|-%:%`(C, elem, rt))*{elem <- `elem*`, rt <- `rt*`} + -- if (|`elem*`| = |`rt*`|) -- (Start_ok: `%|-%:OK`(C, start))?{start <- `start?`} -- (Export_ok: `%|-%:%%`(C, export, nm, xt_E))*{export <- `export*`, nm <- `nm*`, xt_E <- `xt_E*`} + -- if (|`export*`| = |`nm*`|) + -- if (|`export*`| = |`xt_E*`|) -- if $disjoint_(syntax name, nm*{nm <- `nm*`}) -- if (C = C' +++ {TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- if (C' = {TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) - -- if (x*{x <- `x*`} = $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}))) - -- if (jt_I*{jt_I <- `jt_I*`} = $tagsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (gt_I*{gt_I <- `gt_I*`} = $globalsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (mt_I*{mt_I <- `mt_I*`} = $memsxt(xt_I*{xt_I <- `xt_I*`})) - -- if (tt_I*{tt_I <- `tt_I*`} = $tablesxt(xt_I*{xt_I <- `xt_I*`})) - -- if (dt_I*{dt_I <- `dt_I*`} = $funcsxt(xt_I*{xt_I <- `xt_I*`})) + -- if (x*{x <- `x*`} = var_1) + -- if (jt_I*{jt_I <- `jt_I*`} = var_2) + -- if (gt_I*{gt_I <- `gt_I*`} = var_3) + -- if (mt_I*{mt_I <- `mt_I*`} = var_4) + -- if (tt_I*{tt_I <- `tt_I*`} = var_5) + -- if (dt_I*{dt_I <- `dt_I*`} = var_6) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} + -- wf_moduletype: `%`(var_0) + -- (wf_uN: `%%`(32, iter))*{iter <- var_1} + -- (wf_typeuse: `%`(iter))*{iter <- var_2} + -- (wf_globaltype: `%`(iter))*{iter <- var_3} + -- (wf_memtype: `%`(iter))*{iter <- var_4} + -- (wf_tabletype: `%`(iter))*{iter <- var_5} -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) @@ -7368,11 +9747,23 @@ relation Module_ok: `|-%:%`(module, moduletype) -- wf_context: `%`({TYPES [], TAGS jt_I*{jt_I <- `jt_I*`} ++ jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt_I*{mt_I <- `mt_I*`} ++ mt*{mt <- `mt*`}, TABLES tt_I*{tt_I <- `tt_I*`} ++ tt*{tt <- `tt*`}, FUNCS [], DATAS ok*{ok <- `ok*`}, ELEMS rt*{rt <- `rt*`}, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES dt'*{dt' <- `dt'*`}, TAGS [], GLOBALS gt_I*{gt_I <- `gt_I*`}, MEMS [], TABLES [], FUNCS dt_I*{dt_I <- `dt_I*`} ++ dt*{dt <- `dt*`}, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x*{x <- `x*`}, RECS []}) -- wf_nonfuncs: `%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`})) + -- fun_funcsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_6) + -- fun_tablesxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_5) + -- fun_memsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_4) + -- fun_globalsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_3) + -- fun_tagsxt: `%%`(xt_I*{xt_I <- `xt_I*`}, var_2) + -- fun_funcidx_nonfuncs: `%%`(`%%%%%%`_nonfuncs(global*{global <- `global*`}, mem*{mem <- `mem*`}, table*{table <- `table*`}, elem*{elem <- `elem*`}, start?{start <- `start?`}, export*{export <- `export*`}), var_1) + -- fun_clos_moduletype: `%%%`(C, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`}), var_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed2 = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +def $proj_relaxed2_0(x : relaxed2) : (nat) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + def $proj_relaxed2_0{v_num_0 : nat}(`%`_relaxed2(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec relation wf_relaxed2: `%`(relaxed2) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec @@ -7384,6 +9775,11 @@ relation wf_relaxed2: `%`(relaxed2) syntax relaxed4 = | `%`(i : nat) +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +def $proj_relaxed4_0(x : relaxed4) : (nat) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + def $proj_relaxed4_0{v_num_0 : nat}(`%`_relaxed4(v_num_0)) = (v_num_0) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec relation wf_relaxed4: `%`(relaxed4) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec @@ -7394,126 +9790,347 @@ relation wf_relaxed4: `%`(relaxed4) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $relaxed2(relaxed2 : relaxed2, syntax X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $relaxed2{i : relaxed2, syntax X, X_1 : X, X_2 : X}(i, syntax X, X_1, X_2) = (if $ND then [X_1 X_2][i!`%`_relaxed2.0] else [X_1 X_2][0]) + def $relaxed2{i : relaxed2, syntax X, X_1 : X, X_2 : X}(i, syntax X, X_1, X_2) = (if $ND then [X_1 X_2][$proj_relaxed2_0(i).0] else [X_1 X_2][0]) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $relaxed4(relaxed4 : relaxed4, syntax X, X : X, X : X, X : X, X : X) : X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $relaxed4{i : relaxed4, syntax X, X_1 : X, X_2 : X, X_3 : X, X_4 : X}(i, syntax X, X_1, X_2, X_3, X_4) = (if $ND then [X_1 X_2 X_3 X_4][i!`%`_relaxed4.0] else [X_1 X_2 X_3 X_4][0]) + def $relaxed4{i : relaxed4, syntax X, X_1 : X, X_2 : X, X_3 : X, X_4 : X}(i, syntax X, X_1, X_2, X_3, X_4) = (if $ND then [X_1 X_2 X_3 X_4][$proj_relaxed4_0(i).0] else [X_1 X_2 X_3 X_4][0]) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(N : N, iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(N : N, iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{N : N, iN : iN, ret_val : bit*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibits_(N, iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(N : N, fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(N : N, fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{N : N, fN : fN, ret_val : bit*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbits_(N, fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(N : N, iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(N : N, iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{N : N, iN : iN, ret_val : byte*}: + `%%%`(N, iN, ret_val) + -- wf_uN: `%%`(N, iN) + -- if (ret_val = $ibytes_(N, iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(N : N, fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(N : N, fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{N : N, fN : fN, ret_val : byte*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fbytes_(N, fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(numtype : numtype, num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(numtype : numtype, num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{numtype : numtype, num_ : num_, ret_val : byte*}: + `%%%`(numtype, num_, ret_val) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = $nbytes_(numtype, num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(vectype : vectype, vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(vectype : vectype, vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{vectype : vectype, vec_ : vec_, ret_val : byte*}: + `%%%`(vectype, vec_, ret_val) + -- wf_uN: `%%`($vsize(vectype), vec_) + -- if (ret_val = $vbytes_(vectype, vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(storagetype : storagetype, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : byte*}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $zbytes_(storagetype, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(Cnn : Cnn, lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(Cnn : Cnn, lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{Cnn : Cnn, lit_ : lit_, ret_val : byte*}: + `%%%`(Cnn, lit_, ret_val) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), lit_) + -- if (ret_val = $cbytes_(Cnn, lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(N : N, bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(N : N, bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{N : N, var_0 : bit*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(N : N, byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(N : N, byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{N : N, var_0 : byte*, ret_val : fN}: + `%%%`(N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(N, var_0)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(numtype : numtype, byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(numtype, var_0)) + -- wf_num_: `%%`(numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(vectype : vectype, byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(storagetype, var_0, ret_val) + -- wf_storagetype: `%`(storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(storagetype, var_0)) + -- wf_lit_: `%%`(storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int +relation inv_cbytes__is_wf: `%%%`(Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(Cnn, var_0)) + -- wf_lit_: `%%`($storagetype_Cnn(Cnn), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_signed_: `%%%`(N, nat, int) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = (i : nat <:> int) + rule fun_signed__case_0{N : nat, i : nat}: + `%%%`(N, i, (i : nat <:> int)) -- if (i < (2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{N : nat, i : nat}(N, i) = ((i : nat <:> int) - ((2 ^ N) : nat <:> int)) + rule fun_signed__case_1{N : nat, i : nat}: + `%%%`(N, i, ((i : nat <:> int) - ((2 ^ N) : nat <:> int))) -- if (((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) <= i) /\ (i < (2 ^ N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_signed_(N : N, int : int) : nat +relation fun_inv_signed_: `%%%`(N, int, nat) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = (i : int <:> nat) + rule fun_inv_signed__case_0{N : nat, i : int}: + `%%%`(N, i, (i : int <:> nat)) -- if (((0 : nat <:> int) <= i) /\ (i < ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{N : nat, i : int}(N, i) = ((i + ((2 ^ N) : nat <:> int)) : int <:> nat) + rule fun_inv_signed__case_1{N : nat, i : int}: + `%%%`(N, i, ((i + ((2 ^ N) : nat <:> int)) : int <:> nat)) -- if ((- ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= i) /\ (i < (0 : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $sx(storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{consttype : consttype}((consttype : consttype <: storagetype)) = ?(?()) + def $sx(I32_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I64_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(F32_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(F64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{packtype : packtype}((packtype : packtype <: storagetype)) = ?(?(S_sx)) + def $sx(V128_storagetype) = ?(?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I8_storagetype) = ?(?(S_sx)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $sx(I16_storagetype) = ?(?(S_sx)) def $sx{x0 : storagetype}(x0) = ?() -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zero(lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) + def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(F32_lanetype) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $zero(F64_lanetype) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(lanetype : lanetype, ret_val : lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero{Fnn : Fnn}((Fnn : Fnn <: lanetype)) = mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype))))) - -- wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, $fzero($size((Fnn : Fnn <: numtype)))))) + rule zero_is_wf_0{lanetype : lanetype, ret_val : lane_}: + `%%`(lanetype, ret_val) + -- if (ret_val = $zero(lanetype)) + -- wf_lane_: `%%`(lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7541,13 +10158,13 @@ def $sat_s_(N : N, int : int) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN((((((2 ^ N) : nat <:> int) - (i_1!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) + def $ineg_{N : nat, i_1 : uN}(N, i_1) = `%`_iN((((((2 ^ N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iabs_{N : nat, i_1 : uN}(N, i_1) = (if ($signed_(N, i_1!`%`_uN.0) >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + def $iabs_{N : nat, i_1 : uN, var_0 : int}(N, i_1) = (if (var_0 >= (0 : nat <:> int)) then i_1 else $ineg_(N, i_1)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iclz_(N : N, iN : iN) : iN @@ -7559,101 +10176,127 @@ def $ictz_(N : N, iN : iN) : iN def $ipopcnt_(N : N, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iextend_(N : N, M : M, sx : sx, iN : iN) : iN +relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, U_sx, i) = `%`_iN((i!`%`_uN.0 \ (2 ^ M))) - -- wf_uN: `%%`(N, `%`_uN((i!`%`_uN.0 \ (2 ^ M)))) + rule fun_iextend__case_0{N : nat, M : nat, i : uN}: + `%%%%%`(N, M, U_sx, i, `%`_iN(($proj_uN_0(i).0 \ (2 ^ M)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{N : nat, M : nat, i : uN}(N, M, S_sx, i) = `%`_iN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $signed_(M, (i!`%`_uN.0 \ (2 ^ M)))))) + rule fun_iextend__case_1{N : nat, M : nat, i : uN, var_1 : int, var_0 : nat}: + `%%%%%`(N, M, S_sx, i, `%`_iN(var_0)) + -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) + -- fun_inv_signed_: `%%%`(N, var_1, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 + i_2!`%`_uN.0) \ (2 ^ N)))) + def $iadd_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(N, `%`_uN(((((((2 ^ N) + i_1!`%`_uN.0) : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat))) + def $isub_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((((((2 ^ N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ N) : nat <:> int)) : int <:> nat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(N : N, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N))) - -- wf_uN: `%%`(N, `%`_uN(((i_1!`%`_uN.0 * i_2!`%`_uN.0) \ (2 ^ N)))) + def $imul_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $idiv_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN(($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat))) + rule fun_idiv__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?() - -- if ((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + rule fun_idiv__case_3{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}: + `%%%%%`(N, S_sx, i_1, i_2, ?()) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $truncz((($signed_(N, i_1!`%`_uN.0) : int <:> rat) / ($signed_(N, i_2!`%`_uN.0) : int <:> rat)))))) + rule fun_idiv__case_4{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $truncz(((var_1 : int <:> rat) / (var_2 : int <:> rat))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irem_(N : N, sx : sx, iN : iN, iN : iN) : iN? +relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_0{N : nat, i_1 : uN}: + `%%%%%`(N, U_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = ?(`%`_iN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(N, `%`_uN((((i_1!`%`_uN.0 : nat <:> int) - ((i_2!`%`_uN.0 * ($truncz(((i_1!`%`_uN.0 : nat <:> rat) / (i_2!`%`_uN.0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) + rule fun_irem__case_1{N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(N, U_sx, i_1, i_2, ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN}(N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_2{N : nat, i_1 : uN}: + `%%%%%`(N, S_sx, i_1, `%`_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -- if ((j_1 = $signed_(N, i_1!`%`_uN.0)) /\ (j_2 = $signed_(N, i_2!`%`_uN.0))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) + rule fun_irem__case_3{N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(N, S_sx, i_1, i_2, ?(`%`_iN(var_0))) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat))))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_1 - -- if (i_1!`%`_uN.0 <= i_2!`%`_uN.0) + -- if ($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 - -- if (i_1!`%`_uN.0 > i_2!`%`_uN.0) + -- if ($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)) then i_1 else i_2) + def $imin_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 <= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_1 - -- if (i_1!`%`_uN.0 >= i_2!`%`_uN.0) + -- if ($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = i_2 - -- if (i_1!`%`_uN.0 < i_2!`%`_uN.0) + -- if ($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = (if ($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)) then i_1 else i_2) + def $imax_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = (if (var_0 >= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 + i_2!`%`_uN.0) : nat <:> int)))) + def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) + $signed_(N, i_2!`%`_uN.0)))))) + def $iadd_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 + var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int)))) - -- wf_uN: `%%`(N, `%`_uN($sat_u_(N, ((i_1!`%`_uN.0 : nat <:> int) - (i_2!`%`_uN.0 : nat <:> int))))) + def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_iN($sat_u_(N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0))))) - -- wf_uN: `%%`(N, `%`_uN($inv_signed_(N, $sat_s_(N, ($signed_(N, i_1!`%`_uN.0) - $signed_(N, i_2!`%`_uN.0)))))) + def $isub_sat_{N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(N, $sat_s_(N, (var_1 - var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7703,117 +10346,286 @@ def $irelaxed_laneselect_(N : N, iN : iN, iN : iN, iN : iN) : iN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 = 0)))) + def $ieqz_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(N : N, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool((i_1!`%`_uN.0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 =/= 0)))) + def $inez_{N : nat, i_1 : uN}(N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(N : N, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_{N : nat, i_1 : uN, i_2 : uN}(N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 < i_2!`%`_uN.0)))) + def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) < $signed_(N, i_2!`%`_uN.0))))) + def $ilt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 < var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 > i_2!`%`_uN.0)))) + def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) > $signed_(N, i_2!`%`_uN.0))))) + def $igt_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 > var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 <= i_2!`%`_uN.0)))) + def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) <= $signed_(N, i_2!`%`_uN.0))))) + def $ile_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 <= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1!`%`_uN.0 >= i_2!`%`_uN.0)))) + def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{N : nat, i_1 : uN, i_2 : uN}(N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(N, i_1!`%`_uN.0) >= $signed_(N, i_2!`%`_uN.0))))) + def $ige_{N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 >= var_1))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fabs_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fneg__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fneg_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsqrt_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsqrt__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fsqrt_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fceil_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fceil__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fceil_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ffloor_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ffloor__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ffloor_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ftrunc_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ftrunc__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $ftrunc_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fnearest_(N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fnearest__is_wf: `%%%`(N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{N : N, fN : fN, ret_val : fN*}: + `%%%`(N, fN, ret_val) + -- wf_fN: `%%`(N, fN) + -- if (ret_val = $fnearest_(N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fadd_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fadd__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fadd_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsub_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsub__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fsub_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmul_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmul__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmul_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fdiv_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fdiv__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fdiv_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmin_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmin_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmax_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fpmax_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_min_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_min_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_max_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $frelaxed_max_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fcopysign_(N : N, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(N : N, fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{N : N, fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(N, fN, fN_0, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- if (ret_val = $fcopysign_(N, fN, fN_0)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $feq_(N : N, fN : fN, fN : fN) : u32 @@ -7835,9 +10647,31 @@ def $fge_(N : N, fN : fN, fN : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_madd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(N : N, fN : fN, fN : fN, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{N : N, fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(N, fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(N, fN) + -- wf_fN: `%%`(N, fN_0) + -- wf_fN: `%%`(N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(N, fN, fN_0, fN_1)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(M : M, N : N, iN : iN) : iN @@ -7856,12 +10690,39 @@ def $relaxed_trunc__(M : M, N : N, sx : sx, fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $demote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(M : M, N : N, fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(M : M, N : N, fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{M : M, N : N, fN : fN, ret_val : fN*}: + `%%%%`(M, N, fN, ret_val) + -- wf_fN: `%%`(M, fN) + -- if (ret_val = $promote__(M, N, fN)) + -- (wf_fN: `%%`(N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(M : M, N : N, sx : sx, iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(M : M, N : N, sx : sx, iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{M : M, N : N, sx : sx, iN : iN, ret_val : fN}: + `%%%%%`(M, N, sx, iN, ret_val) + -- wf_uN: `%%`(M, iN) + -- if (ret_val = $convert__(M, N, sx, iN)) + -- wf_fN: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN @@ -7869,1446 +10730,5524 @@ def $narrow__(M : M, N : N, sx : sx, iN : iN) : iN def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, num_ : num_) : num_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), c) = mk_lane__0_lane_(numtype, c) - -- wf_lane_: `%%`((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lane_: `%%`((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, num_, ret_val) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, num_)) + -- wf_num_: `%%`(numtype_2, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ +def $lpacknum_(lanetype : lanetype, num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c + def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c)) - -- wf_lit_: `%%`((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, $wrap__($size($lunpack((packtype : packtype <: lanetype))), $psize(packtype), c))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ + def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{numtype : numtype, c : num_}((numtype : numtype <: lanetype), mk_lane__0_lane_(numtype, c)) = c + def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $lunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: lanetype), mk_lane__1_lane_(packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)) - -- wf_num_: `%%`($lunpack((packtype : packtype <: lanetype)), mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ + def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c + def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{packtype : packtype, c : uN}((packtype : packtype <: storagetype), mk_lit__2_lit_(packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c))) - -- wf_lit_: `%%`((!($cunpack((packtype : packtype <: storagetype))) : consttype <: storagetype), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), $size($lunpack((packtype : packtype <: lanetype))), U_sx, c)))) + def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $unop_(numtype : numtype, unop_ : unop_, num_ : num_) : num_* +relation lpacknum__is_wf: `%%%`(lanetype : lanetype, num_ : num_, ret_val : lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CLZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iclz_($sizenn((Inn : addrtype <: numtype)), i))) + rule lpacknum__is_wf_0{lanetype : lanetype, num_ : num_, ret_val : lane_}: + `%%%`(lanetype, num_, ret_val) + -- wf_num_: `%%`($lunpack(lanetype), num_) + -- if (ret_val = $lpacknum_(lanetype, num_)) + -- wf_lane_: `%%`(lanetype, ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(I32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(I64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(F32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(F64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : lit_}(V128_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), lit_) + -- if ($cunpack(storagetype) =/= ?()) + -- if (ret_val = $cpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`(storagetype, ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(I32_lanetype, mk_lane__0_lane_(I32_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(I64_lanetype, mk_lane__0_lane_(I64_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(F32_lanetype, mk_lane__0_lane_(F32_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(lanetype : lanetype, lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{lanetype : lanetype, lane_ : lane_, ret_val : num_}: + `%%%`(lanetype, lane_, ret_val) + -- wf_lane_: `%%`(lanetype, lane_) + -- if (ret_val = $lunpacknum_(lanetype, lane_)) + -- wf_num_: `%%`($lunpack(lanetype), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : lit_}(I32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : lit_}(I64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : lit_}(F32_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : lit_}(F64_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : lit_}(V128_storagetype, c) = c + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cunpacknum__is_wf: `%%%`(storagetype : storagetype, lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cunpacknum__is_wf_0{storagetype : storagetype, lit_ : lit_, ret_val : lit_}: + `%%%`(storagetype, lit_, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_lit_: `%%`(storagetype, lit_) + -- if (ret_val = $cunpacknum_(storagetype, lit_)) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(storagetype))), ret_val) + -- if ($cunpack(storagetype) =/= ?()) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_0{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_1{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_2{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_3{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_4{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_5{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_6{M : nat, i : uN, var_0 : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), M, S_sx, i, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_7{M : nat, i : uN, var_0 : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), M, S_sx, i, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_8{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#1)*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_9{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_10{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#3)*{iter_0#3 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, CTZ_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ictz_($sizenn((Inn : addrtype <: numtype)), i))) + rule fun_unop__case_11{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_12{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#5)*{iter_0#5 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_unop__case_13{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#6)*{iter_0#6 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, POPCNT_unop_Inn), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ipopcnt_($sizenn((Inn : addrtype <: numtype)), i))) + rule fun_unop__case_14{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#7)*{iter_0#7 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Inn : addrtype, M : nat, i : uN}((Inn : addrtype <: numtype), mk_unop__0_unop_(Inn, EXTEND_unop_Inn(`%`_sz(M))), mk_num__0_num_(Inn, i)) = [mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iextend_($sizenn((Inn : addrtype <: numtype)), M, S_sx, i))) + rule fun_unop__case_15{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, ABS_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fabs_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_16{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#9)*{iter_0#9 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEG_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fneg_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_17{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#10)*{iter_0#10 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, SQRT_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsqrt_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_18{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#11)*{iter_0#11 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, CEIL_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fceil_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_19{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, FLOOR_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ffloor_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_20{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0#13)*{iter_0#13 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, TRUNC_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $ftrunc_($sizenn((Fnn : Fnn <: numtype)), f)} + rule fun_unop__case_21{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0#14)*{iter_0#14 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $unop_{Fnn : Fnn, f : fN}((Fnn : Fnn <: numtype), mk_unop__1_unop_(Fnn, NEAREST_unop_Fnn), mk_num__1_num_(Fnn, f)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fnearest_($sizenn((Fnn : Fnn <: numtype)), f)} + rule unop__is_wf_0{numtype : numtype, unop_ : unop_, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%`(numtype, unop_, num_, ret_val) + -- wf_unop_: `%%`(numtype, unop_) + -- wf_num_: `%%`(numtype, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_unop_: `%%%%`(numtype, unop_, num_, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* +relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_0{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_1{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_2{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_3{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_4{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_5{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_6{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#15)*{iter_0#15 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_7{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#16)*{iter_0#16 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_8{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0#17)*{iter_0#17 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ADD_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iadd_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_9{sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0#18)*{iter_0#18 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_10{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_11{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_12{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_13{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_14{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_15{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_16{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_17{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_18{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_19{sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, `%`_u32($proj_uN_0(i_2).0)))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_20{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SUB_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $isub_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_21{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, MUL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $imul_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_22{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, DIV_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($idiv_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} + rule fun_binop__case_23{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, REM_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = mk_num__0_num_(Inn, iter_0)*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} - -- (wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, iter_0)))*{iter_0 <- lift($irem_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2))} + rule fun_binop__case_24{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#19)*{iter_0#19 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, AND_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $iand_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_25{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, OR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ior_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_26{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#21)*{iter_0#21 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, XOR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ixor_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_27{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#22)*{iter_0#22 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishl_($sizenn((Inn : addrtype <: numtype)), i_1, `%`_u32(i_2!`%`_uN.0)))) + rule fun_binop__case_28{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#23)*{iter_0#23 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, SHR_binop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $ishr_($sizenn((Inn : addrtype <: numtype)), sx, i_1, `%`_u32(i_2!`%`_uN.0)))) + rule fun_binop__case_29{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTL_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotl_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_30{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#25)*{iter_0#25 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_binop__0_binop_(Inn, ROTR_binop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = [mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))] - -- wf_num_: `%%`((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $irotr_($sizenn((Inn : addrtype <: numtype)), i_1, i_2))) + rule fun_binop__case_31{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#26)*{iter_0#26 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, ADD_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fadd_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_32{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#27)*{iter_0#27 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, SUB_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fsub_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_33{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MUL_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmul_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_34{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#29)*{iter_0#29 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, DIV_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fdiv_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_35{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#30)*{iter_0#30 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MIN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmin_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_36{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0#31)*{iter_0#31 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, MAX_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fmax_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule fun_binop__case_37{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0#32)*{iter_0#32 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $binop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_binop__1_binop_(Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = mk_num__1_num_(Fnn, iter_0)*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} - -- (wf_num_: `%%`((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0)))*{iter_0 <- $fcopysign_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2)} + rule binop__is_wf_0{numtype : numtype, binop_ : binop_, num_ : num_, num__0 : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype, binop_, num_, num__0, ret_val) + -- wf_binop_: `%%`(numtype, binop_) + -- wf_num_: `%%`(numtype, num_) + -- wf_num_: `%%`(numtype, num__0) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype, ret_val))*{ret_val <- ret_val} + -- fun_binop_: `%%%%%`(numtype, binop_, num_, num__0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $testop_{Inn : addrtype, i : uN}((Inn : addrtype <: numtype), mk_testop__0_testop_(Inn, EQZ_testop_Inn), mk_num__0_num_(Inn, i)) = $ieqz_($sizenn((Inn : addrtype <: numtype)), i) + def $testop_{i : uN}(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i)) = $ieqz_($sizenn($numtype_addrtype(I32_Inn)), i) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $testop_{i : uN}(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i)) = $ieqz_($sizenn($numtype_addrtype(I64_Inn)), i) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, EQ_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ieq_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) + def $relop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, EQ_relop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ieq_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, EQ_relop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ieq_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, NE_relop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ine_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, NE_relop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ine_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, LT_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ilt_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, LT_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ilt_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, GT_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $igt_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, NE_relop_Inn), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ine_($sizenn((Inn : addrtype <: numtype)), i_1, i_2) + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, GT_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $igt_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ilt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, LE_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ile_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GT_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $igt_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, LE_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ile_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, LE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ile_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_relop__0_relop_(I32_Inn, GE_relop_Inn(sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = $ige_($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Inn : addrtype, sx : sx, i_1 : uN, i_2 : uN}((Inn : addrtype <: numtype), mk_relop__0_relop_(Inn, GE_relop_Inn(sx)), mk_num__0_num_(Inn, i_1), mk_num__0_num_(Inn, i_2)) = $ige_($sizenn((Inn : addrtype <: numtype)), sx, i_1, i_2) + def $relop_{sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_relop__0_relop_(I64_Inn, GE_relop_Inn(sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = $ige_($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, EQ_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $feq_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, EQ_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $feq_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, NE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fne_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, EQ_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $feq_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $flt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, NE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fne_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GT_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fgt_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, NE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fne_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, LE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fle_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, LT_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $flt_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $relop_{Fnn : Fnn, f_1 : fN, f_2 : fN}((Fnn : Fnn <: numtype), mk_relop__1_relop_(Fnn, GE_relop_Fnn), mk_num__1_num_(Fnn, f_1), mk_num__1_num_(Fnn, f_2)) = $fge_($sizenn((Fnn : Fnn <: numtype)), f_1, f_2) + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, LT_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $flt_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, GT_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fgt_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GT_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fgt_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, LE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fle_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, LE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fle_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_relop__1_relop_(F32_Fnn, GE_relop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + def $relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $cvtop__(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_) : num_* +relation fun_cvtop__: `%%%%%`(numtype, numtype, cvtop__, num_, num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_0{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_1{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_2{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_3{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_4{i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_5{i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_6{i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_7{i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_8{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#33)*{iter_0#33 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_9{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_10{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#35)*{iter_0#35 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_11{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_12{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#37)*{iter_0#37 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_13{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0#38)*{iter_0#38 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_14{sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#39)*{iter_0#39 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_15{sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0#40)*{iter_0#40 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), sx, f_1))}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_16{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_17{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_18{sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_19{sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), sx, i_1))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_20{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#41)*{iter_0#41 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, EXTEND_cvtop__Inn_1_Inn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $extend__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, i_1))) + rule fun_cvtop___case_21{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_22{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#43)*{iter_0#43 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_23{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_24{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#45)*{iter_0#45 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_25{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_26{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#47)*{iter_0#47 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_27{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cvtop___case_28{i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))]) + -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F32_Fnn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Inn_2 : addrtype, i_1 : uN}((Inn_1 : addrtype <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___0_cvtop__(Inn_1, Inn_2, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(Inn_1, i_1)) = [mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))] - -- wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, $wrap__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), i_1))) + rule fun_cvtop___case_29{i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))]) + -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F32_Fnn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} + rule fun_cvtop___case_30{i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))]) + -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F64_Fnn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, sx : sx, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, TRUNC_SAT_cvtop__Fnn_1_Inn_2(sx)), mk_num__1_num_(Fnn_1, f_1)) = mk_num__0_num_(Inn_2, iter_0)*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} - -- (wf_num_: `%%`((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, iter_0)))*{iter_0 <- lift($trunc_sat__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Inn_2 : addrtype <: numtype)), sx, f_1))} + rule fun_cvtop___case_31{i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))]) + -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F64_Fnn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, sx : sx, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, CONVERT_cvtop__Inn_1_Fnn_2(sx)), mk_num__0_num_(Inn_1, i_1)) = [mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))] - -- wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, $convert__($sizenn1((Inn_1 : addrtype <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), sx, i_1))) + rule fun_cvtop___case_32{f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I32_Inn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $promote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} + rule fun_cvtop___case_33{f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I32_Inn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Fnn_2 : Fnn, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___3_cvtop__(Fnn_1, Fnn_2, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(Fnn_1, f_1)) = mk_num__1_num_(Fnn_2, iter_0)*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} - -- (wf_num_: `%%`((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, iter_0)))*{iter_0 <- $demote__($sizenn1((Fnn_1 : Fnn <: numtype)), $sizenn2((Fnn_2 : Fnn <: numtype)), f_1)} + rule fun_cvtop___case_34{f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I64_Inn))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Inn_1 : addrtype, Fnn_2 : Fnn, i_1 : uN}((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_cvtop___1_cvtop__(Inn_1, Fnn_2, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(Inn_1, i_1)) = [$reinterpret__((Inn_1 : addrtype <: numtype), (Fnn_2 : Fnn <: numtype), mk_num__0_num_(Inn_1, i_1))] - -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) + rule fun_cvtop___case_35{f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))]) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cvtop__{Fnn_1 : Fnn, Inn_2 : addrtype, f_1 : fN}((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_cvtop___2_cvtop__(Fnn_1, Inn_2, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(Fnn_1, f_1)) = [$reinterpret__((Fnn_1 : Fnn <: numtype), (Inn_2 : addrtype <: numtype), mk_num__1_num_(Fnn_1, f_1))] - -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, cvtop__ : cvtop__, num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype_1, numtype_2, cvtop__, num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, cvtop__) + -- wf_num_: `%%`(numtype_1, num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} + -- fun_cvtop__: `%%%%%`(numtype_1, numtype_2, cvtop__, num_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(shape : shape, vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(shape : shape, vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{shape : shape, vec_ : vec_, ret_val : lane_*}: + `%%%`(shape, vec_, ret_val) + -- wf_shape: `%`(shape) + -- wf_uN: `%%`(128, vec_) + -- if (ret_val = $lanes_(shape, vec_)) + -- (wf_lane_: `%%`($lanetype(shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(shape : shape, lane_*) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $zeroop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : zero? +relation fun_zeroop: `%%%%`(shape, shape, vcvtop__, zero?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?() + rule fun_zeroop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = ?() + rule fun_zeroop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} + rule fun_zeroop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = zero?{zero <- `zero?`} + rule fun_zeroop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?(zero) + rule fun_zeroop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $halfop(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__) : half? ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx))) = ?(half) + rule fun_zeroop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx))) = half?{half <- `half?`} + rule fun_zeroop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() + rule fun_zeroop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, `zero?` : zero?}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`}))) = ?() + rule fun_zeroop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, zero : zero}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero))) = ?() + rule fun_zeroop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_zeroop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $half(half : half, nat : nat, nat : nat) : nat ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(LOW_half, i, j) = i + rule fun_zeroop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $half{i : nat, j : nat}(HIGH_half, i, j) = j + rule fun_zeroop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else `%`_iN(0)) - -- wf_uN: `%%`(N, `%`_uN(0)) + rule fun_zeroop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c*{c <- `c*`}, i) = (if (i!`%`_uN.0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[i!`%`_uN.0] else (if ($signed_(N, i!`%`_uN.0) < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[(i!`%`_uN.0 \ |c*{c <- `c*`}|)]))) - -- wf_uN: `%%`(N, `%`_uN(0)) + rule fun_zeroop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3037?{half#3037 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))))}*{c_1 <- `c_1*`} + rule fun_zeroop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3038?{half#3038 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3039?{half#3039 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`})] - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3040?{half#3040 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_zeroop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3041?{half#3041 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_zeroop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3042?{half#3042 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(Jnn, iter_0)*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, iter_0)))*{iter_0 <- $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)), !($proj_lane__2(c_3)))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} + rule fun_zeroop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3043?{half#3043 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`} - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c_3*` : lane_*} c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_3) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`}) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), mk_lane__0_lane_((Fnn : Fnn <: numtype), mk_num__1_num_(Fnn, iter_0))))*{iter_0 <- $f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))), !($proj_num__1(!($proj_lane__0(c_3)))))}*{c_1 <- `c_1*`, c_2 <- `c_2*`, c_3 <- `c_3*`} + rule fun_zeroop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3044?{half#3044 <- `half?`}, sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_zeroop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3441?{zero#3441 <- `zero?`})), zero#3442?{zero#3442 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $lsizenn((Jnn : Jnn <: lanetype)), S_sx, `%`_iN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} - -- (wf_uN: `%%`(1, `%`_uN($f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), !($proj_lane__2(c_2)))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_zeroop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3443?{zero#3443 <- `zero?`})), zero#3444?{zero#3444 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{Fnn : Fnn, M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M)), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $extend__(1, $sizenn((Fnn : Fnn <: numtype)), S_sx, `%`_iN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0))*{c_1 <- `c_1*`, c_2 <- `c_2*`} - -- if ($isize(Inn) = $fsize(Fnn)) - -- wf_shape: `%`(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn : addrtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_((Inn : addrtype <: numtype), mk_num__0_num_(Inn, `%`_uN(c!`%`_uN.0)))))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) - -- (wf_uN: `%%`(1, `%`_uN($f_($sizenn((Fnn : Fnn <: numtype)), !($proj_num__1(!($proj_lane__0(c_1)))), !($proj_num__1(!($proj_lane__0(c_2)))))!`%`_uN.0)))*{c_1 <- `c_1*`, c_2 <- `c_2*`} + rule fun_zeroop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3445?{zero#3445 <- `zero?`})), zero#3446?{zero#3446 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{Jnn : Jnn, M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3447?{zero#3447 <- `zero?`})), zero#3448?{zero#3448 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{Jnn : Jnn, M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3449?{zero#3449 <- `zero?`})), zero#3450?{zero#3450 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(shape : shape, vec_ : vec_) : u32 - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{Jnn : Jnn, M : nat, v_1 : uN, c : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)*{c_1 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_bit: `%`(`%`_bit($ilt_($lsizenn((Jnn : Jnn <: lanetype)), S_sx, !($proj_lane__2(c_1)), `%`_iN(0))!`%`_uN.0)))*{c_1 <- `c_1*`} - -- wf_bit: `%`(`%`_bit(0)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3451?{zero#3451 <- `zero?`})), zero#3452?{zero#3452 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{Jnn : Jnn, M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1))*{c_1 <- `c_1*`}, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, c)))*{c <- `c*`} + rule fun_zeroop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3453?{zero#3453 <- `zero?`})), zero#3454?{zero#3454 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{Jnn : Jnn, M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2) - -- let{`c*` : lane_*} c*{c <- `c*`} = c_1*{c_1 <- `c_1*`} ++ c_2*{c_2 <- `c_2*`}[i!`%`_uN.0]*{i <- `i*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3455?{zero#3455 <- `zero?`})), zero#3456?{zero#3456 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvunop_(vectype : vectype, vvunop : vvunop, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvunop_{Vnn : vectype, v : uN}(Vnn, NOT_vvunop, v) = [$inot_($vsizenn(Vnn), v)] + rule fun_zeroop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3457?{zero#3457 <- `zero?`})), zero#3458?{zero#3458 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, AND_vvbinop, v_1, v_2) = [$iand_($vsizenn(Vnn), v_1, v_2)] + rule fun_zeroop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3459?{zero#3459 <- `zero?`})), zero#3460?{zero#3460 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, ANDNOT_vvbinop, v_1, v_2) = [$iandnot_($vsizenn(Vnn), v_1, v_2)] + rule fun_zeroop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3461?{zero#3461 <- `zero?`})), zero#3462?{zero#3462 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, OR_vvbinop, v_1, v_2) = [$ior_($vsizenn(Vnn), v_1, v_2)] + rule fun_zeroop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3463?{zero#3463 <- `zero?`})), zero#3464?{zero#3464 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, XOR_vvbinop, v_1, v_2) = [$ixor_($vsizenn(Vnn), v_1, v_2)] + rule fun_zeroop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3465?{zero#3465 <- `zero?`})), zero#3466?{zero#3466 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] + rule fun_zeroop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3467?{zero#3467 <- `zero?`})), zero#3468?{zero#3468 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vunop_(shape : shape, vunop_ : vunop_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3469?{zero#3469 <- `zero?`})), zero#3470?{zero#3470 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3471?{zero#3471 <- `zero?`})), zero#3472?{zero#3472 <- `zero?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?(zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Fnn : Fnn, M : nat, v : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vunop__1_vunop_(Fnn, M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vunop_{Jnn : Jnn, M : nat, v : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vunop__0_vunop_(Jnn, M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_zeroop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbinop_(shape : shape, vbinop_ : vbinop_, vec_ : vec_, vec_ : vec_) : vec_* +relation fun_halfop: `%%%%`(shape, shape, vcvtop__, half?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MIN_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imin_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, MAX_vbinop_Jnn_M(sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $imax_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vbinop__0_vbinop_(Jnn, M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), ?(half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3045?{half#3045 <- `half?`}, sx)), half#3046?{half#3046 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3047?{half#3047 <- `half?`}, sx)), half#3048?{half#3048 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3049?{half#3049 <- `half?`}, sx)), half#3050?{half#3050 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbinop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vbinop__1_vbinop_(Fnn, M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3051?{half#3051 <- `half?`}, sx)), half#3052?{half#3052 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vternop_(shape : shape, vternop_ : vternop_, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vternop__0_vternop_(Jnn, M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3053?{half#3053 <- `half?`}, sx)), half#3054?{half#3054 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3055?{half#3055 <- `half?`}, sx)), half#3056?{half#3056 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vternop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vternop__1_vternop_(Fnn, M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3057?{half#3057 <- `half?`}, sx)), half#3058?{half#3058 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3059?{half#3059 <- `half?`}, sx)), half#3060?{half#3060 <- `half?`}) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3473?{zero#3473 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vrelop_(shape : shape, vrelop_ : vrelop_, vec_ : vec_, vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3474?{zero#3474 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3475?{zero#3475 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ilt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3476?{zero#3476 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GT_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $igt_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3477?{zero#3477 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, LE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ile_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3478?{zero#3478 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Jnn : Jnn, M : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vrelop__0_vrelop_(Jnn, M, GE_vrelop_Jnn_M(sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ige_, sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3479?{zero#3479 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3480?{zero#3480 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3481?{zero#3481 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3482?{zero#3482 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3483?{zero#3483 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3484?{zero#3484 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vrelop_{Fnn : Fnn, M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), mk_vrelop__1_vrelop_(Fnn, M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M))) + rule fun_halfop_case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3485?{zero#3485 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3486?{zero#3486 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_) : lane_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__2_lane_(Jnn_2, c)] - -- let{c : iN} c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) + rule fun_halfop_case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3487?{zero#3487 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Jnn_1 : Jnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half?{half <- `half?`}, sx)), mk_lane__2_lane_(Jnn_1, c_1)) = [mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))] - -- let{c : fN} c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))) + rule fun_halfop_case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3488?{zero#3488 <- `zero?`})), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} + rule fun_halfop_case_40{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Inn_2 : addrtype, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(Fnn_1, M_1, (Inn_2 : addrtype <: Jnn), M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero?{zero <- `zero?`})), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = lift(mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))?{c <- `c?`}) - -- let{`c?` : iN?} c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Inn_2 : addrtype <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Inn_2 : addrtype <: numtype), mk_num__0_num_(Inn_2, c))))?{c <- `c?`} + rule fun_halfop_case_41{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + rule fun_halfop_case_42{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{Fnn_1 : Fnn, M_1 : nat, Fnn_2 : Fnn, M_2 : nat, c_1 : fN}(`%X%`_shape((Fnn_1 : Fnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, c_1))) = mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))*{c <- `c*`} - -- let{`c*` : fN*} c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Fnn_2 : Fnn <: lanetype), `%`_dim(M_2))), mk_lane__0_lane_((Fnn_2 : Fnn <: numtype), mk_num__1_num_(Fnn_2, c))))*{c <- `c*`} + rule fun_halfop_case_43{M_1 : nat, M_2 : nat, zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vcvtop__(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v - -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop) = ?())) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + rule fun_halfop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{`c**` : lane_**} c*{c <- `c*`}*{`c*` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1)*{c_1 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c*{c <- `c*`})*{`c*` <- `c**`}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + rule fun_halfop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshiftop_(ishape : ishape, vshiftop_ : vshiftop_, vec_ : vec_, u32 : u32) : vec_ +def $half(half : half, nat : nat, nat : nat) : nat + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $half{i : nat, j : nat}(LOW_half, i, j) = i ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $half{i : nat, j : nat}(HIGH_half, i, j) = j + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshiftop_{Jnn : Jnn, M : nat, sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vshiftop__0_vshiftop_(Jnn, M, SHR_vshiftop_Jnn_M(sx)), v, i) = $ivshiftopsx_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), def $ishr_, sx, v, i) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $iswizzle_lane_{N : nat, `c*` : iN*, i : uN}(N, c#1*{c#1 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else `%`_iN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbitmaskop_(ishape : ishape, vec_ : vec_) : u32 +def $irelaxed_swizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{Jnn : Jnn, M : nat, v : uN}(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), v) = $ivbitmaskop_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + def $irelaxed_swizzle_lane_{N : nat, `c*` : iN*, i : uN, var_0 : int}(N, c#2*{c#2 <- `c*`}, i) = (if ($proj_uN_0(i).0 < |c*{c <- `c*`}|) then c*{c <- `c*`}[$proj_uN_0(i).0] else (if (var_0 < (0 : nat <:> int)) then `%`_iN(0) else $relaxed2($R_swizzle, syntax iN, `%`_iN(0), c*{c <- `c*`}[($proj_uN_0(i).0 \ |c*{c <- `c*`}|)]))) + -- fun_signed_: `%%%`(N, $proj_uN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vswizzlop_(bshape : bshape, vswizzlop_ : vswizzlop_, vec_ : vec_, vec_ : vec_) : vec_ +def $ivunop_(shape : shape, def $f_(N : N, iN : iN) : iN, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#4)*{c#4 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#1*{c_1#1 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#3*{c#3 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#2)))*{c_1#2 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#6)*{c#6 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#3*{c_1#3 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#5*{c#5 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vswizzlop_{M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#8)*{c#8 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#10)*{c#10 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#7*{c_1#7 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#9*{c#9 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshufflop_(bshape : bshape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ +def $fvunop_(shape : shape, def $f_(N : N, fN : fN) : fN*, vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i*{i <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#12*{c#12 <- `c*#2`})*{`c*#2` <- `c**`} + -- let{`c_1*` : lane_*} c_1#9*{c_1#9 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#11*{c#11 <- `c*#1`}*{`c*#1` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49))*{iter_0#49 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- `c_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#50))))*{iter_0#50 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- `c_1*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvunop_{M : nat, def $f_(N : N, fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#14*{c#14 <- `c*#4`})*{`c*#4` <- `c**`} + -- let{`c_1*` : lane_*} c_1#12*{c_1#12 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#13*{c#13 <- `c*#3`}*{`c*#3` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51))*{iter_0#51 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#52))))*{iter_0#52 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- `c_1*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), sx, v_1, v_2) = v - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $narrow__($lsize((Jnn_1 : Jnn <: lanetype)), $lsize((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c'_1)*{c'_1 <- `c'_1*`} ++ mk_lane__2_lane_(Jnn_2, c'_2)*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_1)))*{c'_1 <- `c'_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c'_2)))*{c'_2 <- `c'_2*`} +def $ivbinop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#16)*{c#16 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#15*{c_1#15 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#1*{c_2#1 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#15*{c#15 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- `c_1*`, c_2#2 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#18)*{c#18 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#3*{c_2#3 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#17*{c#17 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- `c_1*`, c_2#4 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#20)*{c#20 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#19*{c_1#19 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#19*{c#19 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- `c_1*`, c_2#6 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#22)*{c#22 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#21*{c_1#21 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#7*{c_2#7 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#21*{c#21 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- `c_1*`, c_2#8 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivadd_pairwise_(N : N, iN*) : iN* +def $ivbinopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#24)*{c#24 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#9*{c_2#9 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#23*{c#23 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- `c_1*`, c_2#10 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#26)*{c#26 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#25*{c_1#25 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- `c_1*`, c_2#12 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i*{i <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax N, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = i!`%`_uN.0*{i <- `i*`}) - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{j_2 <- `j_2*`} + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#28)*{c#28 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#27*{c_1#27 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#13*{c_2#13 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#27*{c#27 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- `c_1*`, c_2#14 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- `c*`})] + -- let{`c_1*` : lane_*} c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#15*{c_2#15 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#29*{c#29 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- `c_1*`, c_2#16 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ +def $ivbinopsxnd_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#32*{c#32 <- `c*#6`})*{`c*#6` <- `c**`} + -- let{`c_1*` : lane_*} c_1#31*{c_1#31 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#31*{c#31 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#53)*{iter_0#53 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- `c_1*`, c_2#18 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#54)))*{iter_0#54 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- `c_1*`, c_2#19 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1) - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#34*{c#34 <- `c*#8`})*{`c*#8` <- `c**`} + -- let{`c_1*` : lane_*} c_1#34*{c_1#34 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#33*{c#33 <- `c*#7`}*{`c*#7` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#55)*{iter_0#55 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- `c_1*`, c_2#21 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#56)))*{iter_0#56 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- `c_1*`, c_2#22 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#36*{c#36 <- `c*#10`})*{`c*#10` <- `c**`} + -- let{`c_1*` : lane_*} c_1#37*{c_1#37 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#35*{c#35 <- `c*#9`}*{`c*#9` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#57)*{iter_0#57 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- `c_1*`, c_2#24 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#58)))*{iter_0#58 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- `c_1*`, c_2#25 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : iN*, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#38*{c#38 <- `c*#12`})*{`c*#12` <- `c**`} + -- let{`c_1*` : lane_*} c_1#40*{c_1#40 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#37*{c#37 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#59)*{iter_0#59 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- `c_1*`, c_2#27 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#60)))*{iter_0#60 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- `c_1*`, c_2#28 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextunop__(ishape_1 : ishape, ishape_2 : ishape, vextunop__ : vextunop__, vec_ : vec_) : vec_ +def $fvbinop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#40*{c#40 <- `c*#14`})*{`c*#14` <- `c**`} + -- let{`c_1*` : lane_*} c_1#43*{c_1#43 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#39*{c#39 <- `c*#13`}*{`c*#13` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61))*{iter_0#61 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- `c_1*`, c_2#30 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#62))))*{iter_0#62 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- `c_1*`, c_2#31 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextunop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1) = $ivextunop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) + def $fvbinop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#42*{c#42 <- `c*#16`})*{`c*#16` <- `c**`} + -- let{`c_1*` : lane_*} c_1#46*{c_1#46 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c**` : lane_**} c#41*{c#41 <- `c*#15`}*{`c*#15` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63))*{iter_0#63 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- `c_1*`, c_2#33 <- `c_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#64))))*{iter_0#64 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- `c_1*`, c_2#34 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_(N : N, iN*, iN*) : iN* +def $ivternopnd_(shape : shape, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#44*{c#44 <- `c*#18`})*{`c*#18` <- `c**`} + -- let{`c_1*` : lane_*} c_1#49*{c_1#49 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#1*{c_3#1 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#43*{c#43 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#65)*{iter_0#65 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- `c_1*`, c_2#36 <- `c_2*`, c_3#2 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#66)))*{iter_0#66 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- `c_1*`, c_2#37 <- `c_2*`, c_3#3 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#46*{c#46 <- `c*#20`})*{`c*#20` <- `c**`} + -- let{`c_1*` : lane_*} c_1#52*{c_1#52 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#4*{c_3#4 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#45*{c#45 <- `c*#19`}*{`c*#19` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#67)*{iter_0#67 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- `c_1*`, c_2#39 <- `c_2*`, c_3#5 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#68)))*{iter_0#68 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- `c_1*`, c_2#40 <- `c_2*`, c_3#6 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#48*{c#48 <- `c*#22`})*{`c*#22` <- `c**`} + -- let{`c_1*` : lane_*} c_1#55*{c_1#55 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#7*{c_3#7 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#47*{c#47 <- `c*#21`}*{`c*#21` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#69)*{iter_0#69 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- `c_1*`, c_2#42 <- `c_2*`, c_3#8 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#70)))*{iter_0#70 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- `c_1*`, c_2#43 <- `c_2*`, c_3#9 <- `c_3*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{M : nat, def $f_(N : N, iN : iN, iN : iN, iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#24`})*{`c*#24` <- `c**`} + -- let{`c_1*` : lane_*} c_1#58*{c_1#58 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#10*{c_3#10 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#49*{c#49 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#71)*{iter_0#71 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- `c_1*`, c_2#45 <- `c_2*`, c_3#11 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#72)))*{iter_0#72 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- `c_1*`, c_2#46 <- `c_2*`, c_3#12 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_sat_(N : N, iN*, iN*) : iN* +def $fvternop_(shape : shape, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#52*{c#52 <- `c*#26`})*{`c*#26` <- `c**`} + -- let{`c_1*` : lane_*} c_1#61*{c_1#61 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#13*{c_3#13 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#51*{c#51 <- `c*#25`}*{`c*#25` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#73))*{iter_0#73 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- `c_1*`, c_2#48 <- `c_2*`, c_3#14 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#74))))*{iter_0#74 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- `c_1*`, c_2#49 <- `c_2*`, c_3#15 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} - -- if ($concat_(syntax iN, [j_1 j_2]*{j_1 <- `j_1*`, j_2 <- `j_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`}) - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{j_2 <- `j_2*`} + def $fvternop_{M : nat, def $f_(N : N, fN : fN, fN : fN, fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#54*{c#54 <- `c*#28`})*{`c*#28` <- `c**`} + -- let{`c_1*` : lane_*} c_1#64*{c_1#64 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c_3*` : lane_*} c_3#16*{c_3#16 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3) + -- let{`c**` : lane_**} c#53*{c#53 <- `c*#27`}*{`c*#27` <- `c**`} = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#75))*{iter_0#75 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- `c_1*`, c_2#51 <- `c_2*`, c_3#17 <- `c_3*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#76))))*{iter_0#76 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- `c_1*`, c_2#52 <- `c_2*`, c_3#18 <- `c_3*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ +def $ivrelop_(shape : shape, def $f_(N : N, iN : iN, iN : iN) : u32, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#56)*{c#56 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#67*{c_1#67 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#55*{c#55 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- `c_1*`, c_2#54 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- `c_1*`, c_2#55 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#58)*{c#58 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#70*{c_1#70 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#57*{c#57 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- `c_1*`, c_2#57 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- `c_1*`, c_2#58 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_lane__2_lane_(Jnn_2, c)*{c <- `c*`}) - -- let{`c_1*` : lane_*} c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1)[i!`%`_uN.0 : k!`%`_uN.0] - -- let{`c_2*` : lane_*} c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2)[i!`%`_uN.0 : k!`%`_uN.0] - -- let{`c'_1*` : iN*} c'_1*{c'_1 <- `c'_1*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_1, !($proj_lane__2(c_1)))*{c_1 <- `c_1*`} - -- let{`c'_2*` : iN*} c'_2*{c'_2 <- `c'_2*`} = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx_2, !($proj_lane__2(c_2)))*{c_2 <- `c_2*`} - -- let{`c*` : iN*} c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`}) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)))*{c <- `c*`} - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#60)*{c#60 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#73*{c_1#73 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#59*{c#59 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- `c_1*`, c_2#60 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- `c_1*`, c_2#61 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{M : nat, def $f_(N : N, iN : iN, iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#62)*{c#62 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#76*{c_1#76 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#61*{c#61 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- `c_1*`, c_2#63 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- `c_1*`, c_2#64 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivmul_(N : N, iN*, iN*) : iN* +def $ivrelopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#64)*{c#64 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#79*{c_1#79 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#63*{c#63 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- `c_1*`, c_2#66 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- `c_1*`, c_2#67 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1*{i_1 <- `i_1*`}, i_2*{i_2 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#66)*{c#66 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#82*{c_1#82 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#65*{c#65 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- `c_1*`, c_2#69 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- `c_1*`, c_2#70 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#68)*{c#68 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#85*{c_1#85 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#67*{c#67 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- `c_1*`, c_2#72 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- `c_1*`, c_2#73 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, iN : iN) : u32, sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#70)*{c#70 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#88*{c_1#88 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#69*{c#69 <- `c*`} = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- `c_1*`, c_2#75 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- `c_1*`, c_2#76 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextbinop__(ishape_1 : ishape, ishape_2 : ishape, vextbinop__ : vextbinop__, vec_ : vec_, vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($half(half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextbinop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) +def $fvrelop_(shape : shape, def $f_(N : N, fN : fN, fN : fN) : u32, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#72).0)))*{c#72 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#91*{c_1#91 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#71*{c#71 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- `c_1*`, c_2#78 <- `c_2*`} + -- if ($isize(Inn) = $fsize(F32_Fnn)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- `c_1*`, c_2#79 <- `c_2*`} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvrelop_{M : nat, def $f_(N : N, fN : fN, fN : fN) : u32, v_1 : uN, v_2 : uN, Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(Inn), `%`_dim(M)), mk_lane__0_lane_($numtype_addrtype(Inn), mk_num__0_num_(Inn, `%`_uN($proj_uN_0(c#74).0)))*{c#74 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#94*{c_1#94 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#73*{c#73 <- `c*`} = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- `c_1*`, c_2#81 <- `c_2*`} + -- if ($isize(Inn) = $fsize(F64_Fnn)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M))) + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- `c_1*`, c_2#82 <- `c_2*`} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextternop__, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_ +def $ivshiftop_(shape : shape, def $f_(N : N, iN : iN, u32 : u32) : iN, vec_ : vec_, u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vextternop__{Jnn_1 : Jnn, M_1 : nat, Jnn_2 : Jnn, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn}(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c - -- if ($jsizenn(Jnn) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) - -- let{M : M} M = (2 * M_2) - -- let{c' : vec_} c' = $vextbinop__(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $vextunop__(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $vbinop_(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), `%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), `%`_ishape(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, Jnn_2, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), mk_vbinop__0_vbinop_(Jnn_2, M_2, ADD_vbinop_Jnn_M)) + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#76)*{c#76 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#97*{c_1#97 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#75*{c#75 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#78)*{c#78 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#99*{c_1#99 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#77*{c#77 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#80)*{c#80 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#79*{c#79 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{M : nat, def $f_(N : N, iN : iN, u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#82)*{c#82 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#103*{c_1#103 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#81*{c#81 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax num = - | CONST(numtype : numtype, num_) +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, vec_ : vec_, u32 : u32) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#84)*{c#84 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#105*{c_1#105 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#83*{c#83 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#86)*{c#86 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#85*{c#85 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#88)*{c#88 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#109*{c_1#109 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#87*{c#87 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{M : nat, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : iN, sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#111*{c_1#111 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c*` : iN*} c#89*{c#89 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_num: `%`(num) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule num_case_0{numtype : numtype, var_0 : num_}: - `%`(CONST_num(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_ivbitmaskop_: `%%%`(shape, vec_, u32) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_0{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#114) =/= ?()))*{c_1#114 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- `c_1*`} + -- (if ($proj_lane__2(c_1#115) =/= ?()))*{c_1#115 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax vec = - | VCONST(vectype : vectype, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#117) =/= ?()))*{c_1#117 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- `c_1*`} + -- (if ($proj_lane__2(c_1#118) =/= ?()))*{c_1#118 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_vec: `%`(vec) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule vec_case_0{vectype : vectype, var_0 : vec_}: - `%`(VCONST_vec(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#120) =/= ?()))*{c_1#120 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- `c_1*`} + -- (if ($proj_lane__2(c_1#121) =/= ?()))*{c_1#121 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax result = - | _VALS(`val*` : val*) - | `(REF.EXN_ADDR%)THROW_REF`(exnaddr : exnaddr) - | TRAP + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- let{`c_1*` : lane_*} c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1#123) =/= ?()))*{c_1#123 <- `c_1*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- `c_1*`} + -- (if ($proj_lane__2(c_1#124) =/= ?()))*{c_1#124 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_result: `%`(result) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_0{`val*` : val*}: - `%`(_VALS_result(`val*`)) - -- (wf_val: `%`(val))*{val <- `val*`} +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), mk_lane__2_lane_(I32_Jnn, c#92)*{c#92 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#91*{c#91 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- `c_1*`}, !($proj_lane__2(c_2#84)))*{c_2#84 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), mk_lane__2_lane_(I64_Jnn, c#94)*{c#94 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#127*{c_1#127 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#85*{c_2#85 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#93*{c#93 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- `c_1*`}, !($proj_lane__2(c_2#86)))*{c_2#86 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), mk_lane__2_lane_(I8_Jnn, c#96)*{c#96 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#129*{c_1#129 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#87*{c_2#87 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#95*{c#95 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- `c_1*`}, !($proj_lane__2(c_2#88)))*{c_2#88 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{M : nat, def $f_(N : N, iN*, iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), mk_lane__2_lane_(I16_Jnn, c#98)*{c#98 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : iN*} c#97*{c#97 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- `c_1*`}, !($proj_lane__2(c_2#90)))*{c_2#90 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_1{exnaddr : exnaddr}: - `%`(`(REF.EXN_ADDR%)THROW_REF`_result(exnaddr)) +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_ivshufflop_: `%%%%%`(shape, laneidx*, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#139040*{i#139040 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#100*{c#100 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#133*{c_1#133 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#91*{c_2#91 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#99*{c#99 <- `c*`} = c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}[$proj_uN_0(i#139043).0]*{i#139043 <- `i*`} + -- (if ($proj_uN_0(i#139043).0 < |c_1#134*{c_1#134 <- `c_1*`} ++ c_2#92*{c_2#92 <- `c_2*`}|))*{i#139043 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_2: - `%`(TRAP_result) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#139047*{i#139047 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#102*{c#102 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#135*{c_1#135 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#93*{c_2#93 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#101*{c#101 <- `c*`} = c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}[$proj_uN_0(i#139050).0]*{i#139050 <- `i*`} + -- (if ($proj_uN_0(i#139050).0 < |c_1#136*{c_1#136 <- `c_1*`} ++ c_2#94*{c_2#94 <- `c_2*`}|))*{i#139050 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax hostfunc = - | `...` + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#139054*{i#139054 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#104*{c#104 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#103*{c#103 <- `c*`} = c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}[$proj_uN_0(i#139057).0]*{i#139057 <- `i*`} + -- (if ($proj_uN_0(i#139057).0 < |c_1#138*{c_1#138 <- `c_1*`} ++ c_2#96*{c_2#96 <- `c_2*`}|))*{i#139057 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funccode = - | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) - | `...` + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#139061*{i#139061 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#106*{c#106 <- `c*`})) + -- let{`c_1*` : lane_*} c_1#139*{c_1#139 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1) + -- let{`c_2*` : lane_*} c_2#97*{c_2#97 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2) + -- let{`c*` : lane_*} c#105*{c#105 <- `c*`} = c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}[$proj_uN_0(i#139064).0]*{i#139064 <- `i*`} + -- (if ($proj_uN_0(i#139064).0 < |c_1#140*{c_1#140 <- `c_1*`} ++ c_2#98*{c_2#98 <- `c_2*`}|))*{i#139064 <- `i*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_funccode: `%`(funccode) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funccode_case_0{typeidx : typeidx, `local*` : local*, expr : expr}: - `%`(FUNC_funccode(typeidx, `local*`, expr)) - -- wf_uN: `%%`(32, typeidx) - -- (wf_local: `%`(local))*{local <- `local*`} - -- (wf_instr: `%`(expr))*{expr <- expr} +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvunop_(vectype : vectype, vvunop : vvunop, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvunop_{Vnn : vectype, v : uN}(Vnn, NOT_vvunop, v) = [$inot_($vsizenn(Vnn), v)] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funccode_case_1: - `%`(`...`_funccode) +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, AND_vvbinop, v_1, v_2) = [$iand_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, ANDNOT_vvbinop, v_1, v_2) = [$iandnot_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, OR_vvbinop, v_1, v_2) = [$ior_($vsizenn(Vnn), v_1, v_2)] + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvbinop_{Vnn : vectype, v_1 : uN, v_2 : uN}(Vnn, XOR_vvbinop, v_1, v_2) = [$ixor_($vsizenn(Vnn), v_1, v_2)] -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax taginst = -{ - TYPE tagtype -} +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $vvternop_(vectype : vectype, vvternop : vvternop, vec_ : vec_, vec_ : vec_, vec_ : vec_) : vec_* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $vvternop_{Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(Vnn), v_1, v_2, v_3)] + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vunop_: `%%%%`(shape, vunop_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_0{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_1{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_2{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_3{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fneg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_4{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_5{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsqrt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_6{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_7{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fceil_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_8{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_9{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ffloor_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_10{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_11{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $ftrunc_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_12{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_13{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fnearest_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_14{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_15{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_16{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_17{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iabs_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_18{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_19{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_20{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_21{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ineg_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_22{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_23{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_24{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_25{M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ipopcnt_, v)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vbinop_: `%%%%%`(shape, vbinop_, vec_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_8{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_9{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_10{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_11{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iadd_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $isub_sat_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imin_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_24{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_25{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_26{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_27{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $imax_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_36{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_37{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_38{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_39{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_40{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_41{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fadd_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_42{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_43{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fsub_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_44{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_45{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmul_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_46{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_47{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fdiv_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_48{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_49{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_50{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_51{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_52{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_53{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmin_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_54{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_55{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fpmax_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_56{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_57{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_min_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_58{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_59{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_max_, v_1, v_2)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vternop_: `%%%%%%`(shape, vternop_, vec_, vec_, vec_, vec_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_0{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_1{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_2{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_3{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_4{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_5{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_6{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vternop__case_7{M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vrelop_: `%%%%%`(shape, vrelop_, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_2{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_3{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ieq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_4{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_5{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_6{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_7{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ine_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_8{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_9{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_10{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_11{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ilt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_12{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_13{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_14{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_15{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $igt_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_16{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_17{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_18{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_19{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ile_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_20{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_21{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_22{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_23{M : nat, sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ige_, sx, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_24{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_25{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $feq_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_26{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_27{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fne_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_28{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_29{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $flt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_30{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_31{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fgt_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_32{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_33{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fle_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_34{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_35{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), def $fge_, v_1, v_2)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_lcvtop__: `%%%%%`(shape, shape, vcvtop__, lane_, lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) + -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_16{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3061?{half#3061 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_17{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3062?{half#3062 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_18{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3063?{half#3063 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_19{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3064?{half#3064 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_20{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3065?{half#3065 <- `half?`}, sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_21{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3066?{half#3066 <- `half?`}, sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_22{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3067?{half#3067 <- `half?`}, sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_23{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half#3068?{half#3068 <- `half?`}, sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) + -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3489?{zero#3489 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#108))?{c#108 <- `c?`})) + -- let{`c?` : iN?} c#107?{c#107 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3490?{zero#3490 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#110))?{c#110 <- `c?`})) + -- let{`c?` : iN?} c#109?{c#109 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3491?{zero#3491 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#112))?{c#112 <- `c?`})) + -- let{`c?` : iN?} c#111?{c#111 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3492?{zero#3492 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#114))?{c#114 <- `c?`})) + -- let{`c?` : iN?} c#113?{c#113 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3493?{zero#3493 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#116))?{c#116 <- `c?`})) + -- let{`c?` : iN?} c#115?{c#115 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3494?{zero#3494 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#118))?{c#118 <- `c?`})) + -- let{`c?` : iN?} c#117?{c#117 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3495?{zero#3495 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#120))?{c#120 <- `c?`})) + -- let{`c?` : iN?} c#119?{c#119 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3496?{zero#3496 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#122))?{c#122 <- `c?`})) + -- let{`c?` : iN?} c#121?{c#121 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3497?{zero#3497 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#124))?{c#124 <- `c?`})) + -- let{`c?` : iN?} c#123?{c#123 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3498?{zero#3498 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#126))?{c#126 <- `c?`})) + -- let{`c?` : iN?} c#125?{c#125 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3499?{zero#3499 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#128))?{c#128 <- `c?`})) + -- let{`c?` : iN?} c#127?{c#127 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3500?{zero#3500 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#130))?{c#130 <- `c?`})) + -- let{`c?` : iN?} c#129?{c#129 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3501?{zero#3501 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#132))?{c#132 <- `c?`})) + -- let{`c?` : iN?} c#131?{c#131 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3502?{zero#3502 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#134))?{c#134 <- `c?`})) + -- let{`c?` : iN?} c#133?{c#133 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3503?{zero#3503 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#136))?{c#136 <- `c?`})) + -- let{`c?` : iN?} c#135?{c#135 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3504?{zero#3504 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#138))?{c#138 <- `c?`})) + -- let{`c?` : iN?} c#137?{c#137 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3505?{zero#3505 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#140))?{c#140 <- `c?`})) + -- let{`c?` : iN?} c#139?{c#139 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3506?{zero#3506 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))?{c#142 <- `c?`})) + -- let{`c?` : iN?} c#141?{c#141 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3507?{zero#3507 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#144))?{c#144 <- `c?`})) + -- let{`c?` : iN?} c#143?{c#143 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3508?{zero#3508 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- `c?`})) + -- let{`c?` : iN?} c#145?{c#145 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3509?{zero#3509 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#148))?{c#148 <- `c?`})) + -- let{`c?` : iN?} c#147?{c#147 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3510?{zero#3510 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#150))?{c#150 <- `c?`})) + -- let{`c?` : iN?} c#149?{c#149 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3511?{zero#3511 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#152))?{c#152 <- `c?`})) + -- let{`c?` : iN?} c#151?{c#151 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3512?{zero#3512 <- `zero?`})), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))?{c#154 <- `c?`})) + -- let{`c?` : iN?} c#153?{c#153 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3513?{zero#3513 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#156))?{c#156 <- `c?`})) + -- let{`c?` : iN?} c#155?{c#155 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3514?{zero#3514 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#158))?{c#158 <- `c?`})) + -- let{`c?` : iN?} c#157?{c#157 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3515?{zero#3515 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#160))?{c#160 <- `c?`})) + -- let{`c?` : iN?} c#159?{c#159 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3516?{zero#3516 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#162))?{c#162 <- `c?`})) + -- let{`c?` : iN?} c#161?{c#161 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3517?{zero#3517 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- `c?`})) + -- let{`c?` : iN?} c#163?{c#163 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3518?{zero#3518 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#166))?{c#166 <- `c?`})) + -- let{`c?` : iN?} c#165?{c#165 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3519?{zero#3519 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#168))?{c#168 <- `c?`})) + -- let{`c?` : iN?} c#167?{c#167 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(sx, zero#3520?{zero#3520 <- `zero?`})), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#170))?{c#170 <- `c?`})) + -- let{`c?` : iN?} c#169?{c#169 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#172))*{c#172 <- `c*`}) + -- let{`c*` : fN*} c#171*{c#171 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#174))*{c#174 <- `c*`}) + -- let{`c*` : fN*} c#173*{c#173 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#176))*{c#176 <- `c*`}) + -- let{`c*` : fN*} c#175*{c#175 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#178))*{c#178 <- `c*`}) + -- let{`c*` : fN*} c#177*{c#177 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#180))*{c#180 <- `c*`}) + -- let{`c*` : fN*} c#179*{c#179 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#182))*{c#182 <- `c*`}) + -- let{`c*` : fN*} c#181*{c#181 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#184))*{c#184 <- `c*`}) + -- let{`c*` : fN*} c#183*{c#183 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#186))*{c#186 <- `c*`}) + -- let{`c*` : fN*} c#185*{c#185 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#188))*{c#188 <- `c*`}) + -- let{`c*` : fN*} c#187*{c#187 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#190))*{c#190 <- `c*`}) + -- let{`c*` : fN*} c#189*{c#189 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#192))*{c#192 <- `c*`}) + -- let{`c*` : fN*} c#191*{c#191 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#194))*{c#194 <- `c*`}) + -- let{`c*` : fN*} c#193*{c#193 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#196))*{c#196 <- `c*`}) + -- let{`c*` : fN*} c#195*{c#195 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#198))*{c#198 <- `c*`}) + -- let{`c*` : fN*} c#197*{c#197 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#200))*{c#200 <- `c*`}) + -- let{`c*` : fN*} c#199*{c#199 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#202))*{c#202 <- `c*`}) + -- let{`c*` : fN*} c#201*{c#201 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, vcvtop__ : vcvtop__, lane_ : lane_, ret_val : lane_*, var_0 : lane_*}: + `%%%%%`(shape_1, shape_2, vcvtop__, lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, vcvtop__) + -- wf_lane_: `%%`($lanetype(shape_1), lane_) + -- if (ret_val = var_0) + -- (wf_lane_: `%%`($lanetype(shape_2), ret_val))*{ret_val <- ret_val} + -- fun_lcvtop__: `%%%%%`(shape_1, shape_2, vcvtop__, lane_, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_0{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M_0)), vcvtop, v_1, v) + -- if ((var_0 = ?()) /\ (var_1 = ?())) + -- let{`c_1*` : lane_*} c_1#141*{c_1#141 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1) + -- let{`c**` : lane_**} c#203*{c#203 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#204*{c#204 <- `c*#30`})*{`c*#30` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if (M = M_0) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#142, var_2))*{var_2 <- `var_2*`, c_1#142 <- `c_1*`} + -- if (|`var_2*`| = |`c_1*`|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_1{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, half : half, `var_1*` : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(half)) + -- let{`c_1*` : lane_*} c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2] + -- let{`c**` : lane_**} c#205*{c#205 <- `c*#31`}*{`c*#31` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#206*{c#206 <- `c*#32`})*{`c*#32` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144, var_1))*{var_1 <- `var_1*`, c_1#144 <- `c_1*`} + -- if (|`var_1*`| = |`c_1*`|) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(ZERO_zero)) + -- let{`c_1*` : lane_*} c_1#145*{c_1#145 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) + -- let{`c**` : lane_**} c#207*{c#207 <- `c*#33`}*{`c*#33` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [$zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#208*{c#208 <- `c*#34`})*{`c*#34` <- `c**`}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146, var_1))*{var_1 <- `var_1*`, c_1#146 <- `c_1*`} + -- if (|`var_1*`| = |`c_1*`|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vshiftop_: `%%%%%`(ishape, vshiftop_, vec_, u32, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_0{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_1{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_2{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_3{M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishl_, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_4{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_5{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_6{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_7{M : nat, sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), def $ishr_, sx, v, i)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vbitmaskop_: `%%%`(ishape, vec_, u32) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_0{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_1{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_2{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbitmaskop__case_3{M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vswizzlop_: `%%%%%`(bshape, vswizzlop_, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vswizzlop__case_0{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $iswizzle_lane_, v_1, v_2)) + -- if (M = M_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vswizzlop__case_1{M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $irelaxed_swizzle_lane_, v_1, v_2)) + -- if (M = M_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vshufflop_: `%%%%%`(bshape, laneidx*, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(M))), i#139530*{i#139530 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vnarrowop__: `%%%%%%`(shape, shape, sx, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#147*{c_1#147 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#99*{c_2#99 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#1*{c'_1#1 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#148)))*{c_1#148 <- `c_1*`} + -- (if ($proj_lane__2(c_1#148) =/= ?()))*{c_1#148 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#1*{c'_2#1 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#100)))*{c_2#100 <- `c_2*`} + -- (if ($proj_lane__2(c_2#100) =/= ?()))*{c_2#100 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#2)*{c'_1#2 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#2)*{c'_2#2 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#3)))*{c'_1#3 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#3)))*{c'_2#3 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#149*{c_1#149 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#101*{c_2#101 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#4*{c'_1#4 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#150)))*{c_1#150 <- `c_1*`} + -- (if ($proj_lane__2(c_1#150) =/= ?()))*{c_1#150 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#4*{c'_2#4 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#102)))*{c_2#102 <- `c_2*`} + -- (if ($proj_lane__2(c_2#102) =/= ?()))*{c_2#102 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#5)*{c'_1#5 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#5)*{c'_2#5 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#6)))*{c'_1#6 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#6)))*{c'_2#6 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#151*{c_1#151 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#103*{c_2#103 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#7*{c'_1#7 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#152)))*{c_1#152 <- `c_1*`} + -- (if ($proj_lane__2(c_1#152) =/= ?()))*{c_1#152 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#7*{c'_2#7 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#104)))*{c_2#104 <- `c_2*`} + -- (if ($proj_lane__2(c_2#104) =/= ?()))*{c_2#104 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#8)*{c'_1#8 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#8)*{c'_2#8 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#9)))*{c'_1#9 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#9)))*{c'_2#9 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#153*{c_1#153 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#105*{c_2#105 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#10*{c'_1#10 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#154)))*{c_1#154 <- `c_1*`} + -- (if ($proj_lane__2(c_1#154) =/= ?()))*{c_1#154 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#10*{c'_2#10 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#106)))*{c_2#106 <- `c_2*`} + -- (if ($proj_lane__2(c_2#106) =/= ?()))*{c_2#106 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#11)*{c'_1#11 <- `c'_1*`} ++ mk_lane__2_lane_(I32_Jnn, c'_2#11)*{c'_2#11 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#12)))*{c'_1#12 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#12)))*{c'_2#12 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#155*{c_1#155 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#13*{c'_1#13 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#156)))*{c_1#156 <- `c_1*`} + -- (if ($proj_lane__2(c_1#156) =/= ?()))*{c_1#156 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#13*{c'_2#13 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#108)))*{c_2#108 <- `c_2*`} + -- (if ($proj_lane__2(c_2#108) =/= ?()))*{c_2#108 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#14)*{c'_1#14 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#14)*{c'_2#14 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#15)))*{c'_1#15 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#15)))*{c'_2#15 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#157*{c_1#157 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#109*{c_2#109 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#16*{c'_1#16 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#158)))*{c_1#158 <- `c_1*`} + -- (if ($proj_lane__2(c_1#158) =/= ?()))*{c_1#158 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#16*{c'_2#16 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#110)))*{c_2#110 <- `c_2*`} + -- (if ($proj_lane__2(c_2#110) =/= ?()))*{c_2#110 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#17)*{c'_1#17 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#17)*{c'_2#17 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#18)))*{c'_1#18 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#18)))*{c'_2#18 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#159*{c_1#159 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#111*{c_2#111 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#19*{c'_1#19 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#160)))*{c_1#160 <- `c_1*`} + -- (if ($proj_lane__2(c_1#160) =/= ?()))*{c_1#160 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#19*{c'_2#19 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#112)))*{c_2#112 <- `c_2*`} + -- (if ($proj_lane__2(c_2#112) =/= ?()))*{c_2#112 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#20)*{c'_1#20 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#20)*{c'_2#20 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#21)))*{c'_1#21 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#21)))*{c'_2#21 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#113*{c_2#113 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#22*{c'_1#22 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#162)))*{c_1#162 <- `c_1*`} + -- (if ($proj_lane__2(c_1#162) =/= ?()))*{c_1#162 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#22*{c'_2#22 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#114)))*{c_2#114 <- `c_2*`} + -- (if ($proj_lane__2(c_2#114) =/= ?()))*{c_2#114 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#23)*{c'_1#23 <- `c'_1*`} ++ mk_lane__2_lane_(I64_Jnn, c'_2#23)*{c'_2#23 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#24)))*{c'_1#24 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#24)))*{c'_2#24 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#163*{c_1#163 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#115*{c_2#115 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#25*{c'_1#25 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#164)))*{c_1#164 <- `c_1*`} + -- (if ($proj_lane__2(c_1#164) =/= ?()))*{c_1#164 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#25*{c'_2#25 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#116)))*{c_2#116 <- `c_2*`} + -- (if ($proj_lane__2(c_2#116) =/= ?()))*{c_2#116 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#26)*{c'_1#26 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#26)*{c'_2#26 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#27)))*{c'_1#27 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#27)))*{c'_2#27 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#165*{c_1#165 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#117*{c_2#117 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#28*{c'_1#28 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#166)))*{c_1#166 <- `c_1*`} + -- (if ($proj_lane__2(c_1#166) =/= ?()))*{c_1#166 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#28*{c'_2#28 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#118)))*{c_2#118 <- `c_2*`} + -- (if ($proj_lane__2(c_2#118) =/= ?()))*{c_2#118 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#29)*{c'_1#29 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#29)*{c'_2#29 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#30)))*{c'_1#30 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#30)))*{c'_2#30 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#167*{c_1#167 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#119*{c_2#119 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#31*{c'_1#31 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#168)))*{c_1#168 <- `c_1*`} + -- (if ($proj_lane__2(c_1#168) =/= ?()))*{c_1#168 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#31*{c'_2#31 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- `c_2*`} + -- (if ($proj_lane__2(c_2#120) =/= ?()))*{c_2#120 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#32)*{c'_1#32 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#32)*{c'_2#32 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#33)))*{c'_1#33 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#33)))*{c'_2#33 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#169*{c_1#169 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#121*{c_2#121 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#34*{c'_1#34 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#170)))*{c_1#170 <- `c_1*`} + -- (if ($proj_lane__2(c_1#170) =/= ?()))*{c_1#170 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#34*{c'_2#34 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#122)))*{c_2#122 <- `c_2*`} + -- (if ($proj_lane__2(c_2#122) =/= ?()))*{c_2#122 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#35)*{c'_1#35 <- `c'_1*`} ++ mk_lane__2_lane_(I8_Jnn, c'_2#35)*{c'_2#35 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#36)))*{c'_1#36 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#36)))*{c'_2#36 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#171*{c_1#171 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#123*{c_2#123 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#37*{c'_1#37 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#172)))*{c_1#172 <- `c_1*`} + -- (if ($proj_lane__2(c_1#172) =/= ?()))*{c_1#172 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#37*{c'_2#37 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#124)))*{c_2#124 <- `c_2*`} + -- (if ($proj_lane__2(c_2#124) =/= ?()))*{c_2#124 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#38)*{c'_1#38 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#38)*{c'_2#38 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#39)))*{c'_1#39 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#39)))*{c'_2#39 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#125*{c_2#125 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#40*{c'_1#40 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#174)))*{c_1#174 <- `c_1*`} + -- (if ($proj_lane__2(c_1#174) =/= ?()))*{c_1#174 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#40*{c'_2#40 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- `c_2*`} + -- (if ($proj_lane__2(c_2#126) =/= ?()))*{c_2#126 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#41)*{c'_1#41 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#41)*{c'_2#41 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#42)))*{c'_1#42 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#42)))*{c'_2#42 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#175*{c_1#175 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#127*{c_2#127 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#43*{c'_1#43 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#176)))*{c_1#176 <- `c_1*`} + -- (if ($proj_lane__2(c_1#176) =/= ?()))*{c_1#176 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#43*{c'_2#43 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#128)))*{c_2#128 <- `c_2*`} + -- (if ($proj_lane__2(c_2#128) =/= ?()))*{c_2#128 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#44)*{c'_1#44 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#44)*{c'_2#44 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#45)))*{c'_1#45 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#45)))*{c'_2#45 <- `c'_2*`} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- let{`c_1*` : lane_*} c_1#177*{c_1#177 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c_2*` : lane_*} c_2#129*{c_2#129 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) + -- let{`c'_1*` : iN*} c'_1#46*{c'_1#46 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#178)))*{c_1#178 <- `c_1*`} + -- (if ($proj_lane__2(c_1#178) =/= ?()))*{c_1#178 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#46*{c'_2#46 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#130)))*{c_2#130 <- `c_2*`} + -- (if ($proj_lane__2(c_2#130) =/= ?()))*{c_2#130 <- `c_2*`} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#47)*{c'_1#47 <- `c'_1*`} ++ mk_lane__2_lane_(I16_Jnn, c'_2#47)*{c'_2#47 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#48)))*{c'_1#48 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#48)))*{c'_2#48 <- `c'_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivadd_pairwise_(N : N, iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivadd_pairwise_{N : nat, `i*` : iN*, `j_1*` : N*, `j_2*` : N*}(N, i#139675*{i#139675 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- `j_1*`, j_2#1 <- `j_2*`}) = $proj_uN_0(i#139676).0*{i#139676 <- `i*`}) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx : sx, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#210)*{c#210 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#49*{c'_1#49 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`} + -- let{`c*` : iN*} c#209*{c#209 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#50*{c'_1#50 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#212)*{c#212 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#181*{c_1#181 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#51*{c'_1#51 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- `c_1*`} + -- let{`c*` : iN*} c#211*{c#211 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#52*{c'_1#52 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#214)*{c#214 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#183*{c_1#183 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- `c_1*`} + -- let{`c*` : iN*} c#213*{c#213 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#216)*{c#216 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#55*{c'_1#55 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`} + -- let{`c*` : iN*} c#215*{c#215 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#56*{c'_1#56 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#218)*{c#218 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#187*{c_1#187 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#57*{c'_1#57 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- `c_1*`} + -- let{`c*` : iN*} c#217*{c#217 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#58*{c'_1#58 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#220)*{c#220 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#189*{c_1#189 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- `c_1*`} + -- let{`c*` : iN*} c#219*{c#219 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#60*{c'_1#60 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#222)*{c#222 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#61*{c'_1#61 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`} + -- let{`c*` : iN*} c#221*{c#221 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#62*{c'_1#62 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#224)*{c#224 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#193*{c_1#193 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#63*{c'_1#63 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- `c_1*`} + -- let{`c*` : iN*} c#223*{c#223 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#64*{c'_1#64 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#226)*{c#226 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#195*{c_1#195 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- `c_1*`} + -- let{`c*` : iN*} c#225*{c#225 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#66*{c'_1#66 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#228)*{c#228 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#67*{c'_1#67 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`} + -- let{`c*` : iN*} c#227*{c#227 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#68*{c'_1#68 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#230)*{c#230 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#199*{c_1#199 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#69*{c'_1#69 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- `c_1*`} + -- let{`c*` : iN*} c#229*{c#229 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#70*{c'_1#70 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#232)*{c#232 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#201*{c_1#201 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- `c_1*`} + -- let{`c*` : iN*} c#231*{c#231 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#72*{c'_1#72 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#234)*{c#234 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#73*{c'_1#73 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`} + -- let{`c*` : iN*} c#233*{c#233 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#74*{c'_1#74 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#236)*{c#236 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#205*{c_1#205 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#75*{c'_1#75 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- `c_1*`} + -- let{`c*` : iN*} c#235*{c#235 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#76*{c'_1#76 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#238)*{c#238 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#207*{c_1#207 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- `c_1*`} + -- let{`c*` : iN*} c#237*{c#237 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#78*{c'_1#78 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*) : iN*, sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#240)*{c#240 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) + -- let{`c'_1*` : iN*} c'_1#79*{c'_1#79 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`} + -- let{`c*` : iN*} c#239*{c#239 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#80*{c'_1#80 <- `c'_1*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vextunop__: `%%%%%`(ishape, ishape, vextunop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_0{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_1{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_2{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_3{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_4{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_5{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_6{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_7{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_8{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_9{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_10{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_11{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_12{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_13{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_14{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_15{M_1 : nat, M_2 : nat, sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivdot_(N : N, iN*, iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivdot_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#1*{i_1#1 <- `i_1*`}, i_2#1*{i_2#1 <- `i_2*`}) = $iadd_(N, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $imul_(N, i_1#2, i_2#2)*{i_1#2 <- `i_1*`, i_2#2 <- `i_2*`}) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivdot_sat_(N : N, iN*, iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivdot_sat_{N : nat, `i_1*` : iN*, `i_2*` : iN*, `j_1*` : iN*, `j_2*` : iN*}(N, i_1#3*{i_1#3 <- `i_1*`}, i_2#3*{i_2#3 <- `i_2*`}) = $iadd_sat_(N, S_sx, j_1, j_2)*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- `j_1*`, j_2#3 <- `j_2*`}) = $imul_(N, i_1#4, i_2#4)*{i_1#4 <- `i_1*`, i_2#4 <- `i_2*`}) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*, iN*) : iN*, sx : sx, sx : sx, laneidx : laneidx, laneidx : laneidx, vec_ : vec_, vec_ : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#242)*{c#242 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#211*{c_1#211 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#81*{c'_1#81 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#49*{c'_2#49 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`} + -- let{`c*` : iN*} c#241*{c#241 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#82*{c'_1#82 <- `c'_1*`}, c'_2#50*{c'_2#50 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#244)*{c#244 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#213*{c_1#213 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#133*{c_2#133 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#51*{c'_2#51 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- `c_2*`} + -- let{`c*` : iN*} c#243*{c#243 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#84*{c'_1#84 <- `c'_1*`}, c'_2#52*{c'_2#52 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#246)*{c#246 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#135*{c_2#135 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#85*{c'_1#85 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- `c_2*`} + -- let{`c*` : iN*} c#245*{c#245 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#86*{c'_1#86 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#248)*{c#248 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#217*{c_1#217 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#87*{c'_1#87 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#55*{c'_2#55 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`} + -- let{`c*` : iN*} c#247*{c#247 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#88*{c'_1#88 <- `c'_1*`}, c'_2#56*{c'_2#56 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#250)*{c#250 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#219*{c_1#219 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#139*{c_2#139 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#57*{c'_2#57 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- `c_2*`} + -- let{`c*` : iN*} c#249*{c#249 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#90*{c'_1#90 <- `c'_1*`}, c'_2#58*{c'_2#58 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#252)*{c#252 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#141*{c_2#141 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#91*{c'_1#91 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- `c_2*`} + -- let{`c*` : iN*} c#251*{c#251 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#92*{c'_1#92 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#254)*{c#254 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#223*{c_1#223 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#93*{c'_1#93 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#61*{c'_2#61 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`} + -- let{`c*` : iN*} c#253*{c#253 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#94*{c'_1#94 <- `c'_1*`}, c'_2#62*{c'_2#62 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#256)*{c#256 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#225*{c_1#225 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#145*{c_2#145 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#63*{c'_2#63 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- `c_2*`} + -- let{`c*` : iN*} c#255*{c#255 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#96*{c'_1#96 <- `c'_1*`}, c'_2#64*{c'_2#64 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#258)*{c#258 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#147*{c_2#147 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#97*{c'_1#97 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- `c_2*`} + -- let{`c*` : iN*} c#257*{c#257 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#98*{c'_1#98 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#260)*{c#260 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#229*{c_1#229 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#99*{c'_1#99 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#67*{c'_2#67 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`} + -- let{`c*` : iN*} c#259*{c#259 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#100*{c'_1#100 <- `c'_1*`}, c'_2#68*{c'_2#68 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#262)*{c#262 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#231*{c_1#231 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#151*{c_2#151 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#69*{c'_2#69 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- `c_2*`} + -- let{`c*` : iN*} c#261*{c#261 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#70*{c'_2#70 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#264)*{c#264 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#153*{c_2#153 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#103*{c'_1#103 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- `c_2*`} + -- let{`c*` : iN*} c#263*{c#263 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#104*{c'_1#104 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#266)*{c#266 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#235*{c_1#235 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#105*{c'_1#105 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#73*{c'_2#73 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`} + -- let{`c*` : iN*} c#265*{c#265 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#106*{c'_1#106 <- `c'_1*`}, c'_2#74*{c'_2#74 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#268)*{c#268 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#237*{c_1#237 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#157*{c_2#157 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#75*{c'_2#75 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- `c_2*`} + -- let{`c*` : iN*} c#267*{c#267 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#76*{c'_2#76 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#270)*{c#270 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#159*{c_2#159 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#109*{c'_1#109 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- `c_2*`} + -- let{`c*` : iN*} c#269*{c#269 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#110*{c'_1#110 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#272)*{c#272 <- `c*`}) + -- let{`c_1*` : lane_*} c_1#241*{c_1#241 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c_2*` : lane_*} c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{`c'_1*` : iN*} c'_1#111*{c'_1#111 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- `c_1*`} + -- let{`c'_2*` : iN*} c'_2#79*{c'_2#79 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`} + -- let{`c*` : iN*} c#271*{c#271 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#112*{c'_1#112 <- `c'_1*`}, c'_2#80*{c'_2#80 <- `c'_2*`}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivmul_(N : N, iN*, iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivmul_{N : nat, `i_1*` : iN*, `i_2*` : iN*}(N, i_1#5*{i_1#5 <- `i_1*`}, i_2#5*{i_2#5 <- `i_2*`}) = $imul_(N, i_1, i_2)*{i_1 <- `i_1*`, i_2 <- `i_2*`} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vextbinop__: `%%%%%%`(ishape, ishape, vextbinop__, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_0{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_1{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_2{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_3{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_4{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_5{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_6{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_7{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_8{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_9{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_10{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_11{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_12{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_13{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_14{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_15{M_1 : nat, M_2 : nat, half : half, sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(half, sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, sx, sx, `%`_laneidx($half(half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_16{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_17{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_18{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_19{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_20{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_21{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_22{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_23{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_24{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_25{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_26{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_27{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_28{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_29{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_30{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_31{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_32{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_33{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_34{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_35{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_36{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_37{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_38{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_39{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_40{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_41{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_42{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_43{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_44{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_45{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_46{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_47{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_0{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_1{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_2{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_3{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_4{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_5{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_6{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_7{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_8{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_9{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_10{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_11{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_12{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_13{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_14{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_15{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) + -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- let{M : M} M = (2 * M_2) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)))) + -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) + -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(Jnn, M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, Jnn, M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax num = + | CONST(numtype : numtype, num_) + +def $val_num(num) : val + def $val_num{x0 : numtype, x1 : num_}(CONST_num(x0, x1)) = CONST_val(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_num: `%`(num) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule num_case_0{numtype : numtype, var_0 : num_}: + `%`(CONST_num(numtype, var_0)) + -- wf_num_: `%%`(numtype, var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax vec = + | VCONST(vectype : vectype, vec_) + +def $val_vec(vec) : val + def $val_vec{x0 : vectype, x1 : vec_}(VCONST_vec(x0, x1)) = VCONST_val(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_vec: `%`(vec) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule vec_case_0{vectype : vectype, var_0 : vec_}: + `%`(VCONST_vec(vectype, var_0)) + -- wf_uN: `%%`($vsize(vectype), var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax result = + | _VALS(`val*` : val*) + | `(REF.EXN_ADDR%)THROW_REF`(exnaddr : exnaddr) + | TRAP + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_result: `%`(result) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule result_case_0{`val*` : val*}: + `%`(_VALS_result(`val*`)) + -- (wf_val: `%`(val))*{val <- `val*`} + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule result_case_1{exnaddr : exnaddr}: + `%`(`(REF.EXN_ADDR%)THROW_REF`_result(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule result_case_2: + `%`(TRAP_result) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax hostfunc = + | `...` + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax funccode = + | FUNC(typeidx : typeidx, `local*` : local*, expr : expr) + | `...` + +def $funccode_func(func) : funccode + def $funccode_func{x0 : typeidx, x1 : local*, x2 : expr}(FUNC_func(x0, x1, x2)) = FUNC_funccode(x0, x1, x2) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_funccode: `%`(funccode) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funccode_case_0{typeidx : typeidx, `local*` : local*, expr : expr}: + `%`(FUNC_funccode(typeidx, `local*`, expr)) + -- wf_uN: `%%`(32, typeidx) + -- (wf_local: `%`(local))*{local <- `local*`} + -- (wf_instr: `%`(expr))*{expr <- expr} + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funccode_case_1: + `%`(`...`_funccode) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax taginst = +{ + TYPE tagtype +} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_taginst: `%`(taginst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule taginst_case_{var_0 : tagtype}: - `%`({TYPE var_0}) - -- wf_typeuse: `%`(var_0) + rule taginst_case_{var_0 : tagtype}: + `%`({TYPE var_0}) + -- wf_typeuse: `%`(var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax globalinst = +{ + TYPE globaltype, + VALUE val +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_globalinst: `%`(globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_case_{var_0 : globaltype, var_1 : val}: + `%`({TYPE var_0, VALUE var_1}) + -- wf_globaltype: `%`(var_0) + -- wf_val: `%`(var_1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax meminst = +{ + TYPE memtype, + BYTES byte* +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_meminst: `%`(meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_case_{var_0 : memtype, var_1 : byte*}: + `%`({TYPE var_0, BYTES var_1}) + -- wf_memtype: `%`(var_0) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax tableinst = +{ + TYPE tabletype, + REFS ref* +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_tableinst: `%`(tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_case_{var_0 : tabletype, var_1 : ref*}: + `%`({TYPE var_0, REFS var_1}) + -- wf_tabletype: `%`(var_0) + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax funcinst = +{ + TYPE deftype, + MODULE moduleinst, + CODE funccode +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_funcinst: `%`(funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_case_{var_0 : deftype, var_1 : moduleinst, var_2 : funccode}: + `%`({TYPE var_0, MODULE var_1, CODE var_2}) + -- wf_moduleinst: `%`(var_1) + -- wf_funccode: `%`(var_2) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax datainst = +{ + BYTES byte* +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_datainst: `%`(datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_case_{var_0 : byte*}: + `%`({BYTES var_0}) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax eleminst = +{ + TYPE elemtype, + REFS ref* +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_eleminst: `%`(eleminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_case_{var_0 : elemtype, var_1 : ref*}: + `%`({TYPE var_0, REFS var_1}) + -- wf_reftype: `%`(var_0) + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax packval = + | PACK(packtype : packtype, iN) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_packval: `%`(packval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packval_case_0{packtype : packtype, var_0 : iN}: + `%`(PACK_packval(packtype, var_0)) + -- wf_uN: `%%`($psize(packtype), var_0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax fieldval = + | CONST(numtype : numtype, num_) + | VCONST(vectype : vectype, vec_) + | `REF.I31_NUM`(u31 : u31) + | `REF.NULL_ADDR` + | `REF.STRUCT_ADDR`(structaddr : structaddr) + | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) + | `REF.FUNC_ADDR`(funcaddr : funcaddr) + | `REF.EXN_ADDR`(exnaddr : exnaddr) + | `REF.HOST_ADDR`(hostaddr : hostaddr) + | `REF.EXTERN`(ref : ref) + | PACK(packtype : packtype, iN) + +def $fieldval_packval(packval) : fieldval + def $fieldval_packval{x0 : packtype, x1 : iN}(PACK_packval(x0, x1)) = PACK_fieldval(x0, x1) + +def $fieldval_ref(ref) : fieldval + def $fieldval_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_fieldval(x0) + def $fieldval_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_fieldval + def $fieldval_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_fieldval(x0) + def $fieldval_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_fieldval(x0) + +def $fieldval_val(val) : fieldval + def $fieldval_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_fieldval(x0, x1) + def $fieldval_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_fieldval(x0, x1) + def $fieldval_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_fieldval(x0) + def $fieldval_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_fieldval + def $fieldval_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) + def $fieldval_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) + def $fieldval_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_fieldval(x0) + def $fieldval_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_fieldval(x0) + def $fieldval_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_fieldval(x0) + def $fieldval_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_fieldval(x0) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_fieldval: `%`(fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_0{numtype : numtype, var_0 : num_}: + `%`(CONST_fieldval(numtype, var_0)) + -- wf_num_: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_1{vectype : vectype, var_0 : vec_}: + `%`(VCONST_fieldval(vectype, var_0)) + -- wf_uN: `%%`($vsize(vectype), var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_2{u31 : u31}: + `%`(`REF.I31_NUM`_fieldval(u31)) + -- wf_uN: `%%`(31, u31) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_3: + `%`(`REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_4{structaddr : structaddr}: + `%`(`REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_5{arrayaddr : arrayaddr}: + `%`(`REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_6{funcaddr : funcaddr}: + `%`(`REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_7{exnaddr : exnaddr}: + `%`(`REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_8{hostaddr : hostaddr}: + `%`(`REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_9{ref : ref}: + `%`(`REF.EXTERN`_fieldval(ref)) + -- wf_ref: `%`(ref) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_10{packtype : packtype, var_0 : iN}: + `%`(PACK_fieldval(packtype, var_0)) + -- wf_uN: `%%`($psize(packtype), var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax globalinst = +syntax structinst = { - TYPE globaltype, - VALUE val + TYPE deftype, + FIELDS fieldval* } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_globalinst: `%`(globalinst) +relation wf_structinst: `%`(structinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule globalinst_case_{var_0 : globaltype, var_1 : val}: - `%`({TYPE var_0, VALUE var_1}) - -- wf_globaltype: `%`(var_0) - -- wf_val: `%`(var_1) + rule structinst_case_{var_0 : deftype, var_1 : fieldval*}: + `%`({TYPE var_0, FIELDS var_1}) + -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax meminst = +syntax arrayinst = { - TYPE memtype, - BYTES byte* + TYPE deftype, + FIELDS fieldval* } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_meminst: `%`(meminst) +relation wf_arrayinst: `%`(arrayinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule meminst_case_{var_0 : memtype, var_1 : byte*}: - `%`({TYPE var_0, BYTES var_1}) - -- wf_memtype: `%`(var_0) - -- (wf_byte: `%`(var_1))*{var_1 <- var_1} + rule arrayinst_case_{var_0 : deftype, var_1 : fieldval*}: + `%`({TYPE var_0, FIELDS var_1}) + -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax tableinst = +syntax exninst = { - TYPE tabletype, - REFS ref* + TAG tagaddr, + FIELDS val* } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_tableinst: `%`(tableinst) +relation wf_exninst: `%`(exninst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule tableinst_case_{var_0 : tabletype, var_1 : ref*}: - `%`({TYPE var_0, REFS var_1}) - -- wf_tabletype: `%`(var_0) - -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + rule exninst_case_{var_0 : tagaddr, var_1 : val*}: + `%`({TAG var_0, FIELDS var_1}) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funcinst = +syntax store = { - TYPE deftype, - MODULE moduleinst, - CODE funccode + TAGS taginst*, + GLOBALS globalinst*, + MEMS meminst*, + TABLES tableinst*, + FUNCS funcinst*, + DATAS datainst*, + ELEMS eleminst*, + STRUCTS structinst*, + ARRAYS arrayinst*, + EXNS exninst* +} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_store: `%`(store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_case_{var_0 : taginst*, var_1 : globalinst*, var_2 : meminst*, var_3 : tableinst*, var_4 : funcinst*, var_5 : datainst*, var_6 : eleminst*, var_7 : structinst*, var_8 : arrayinst*, var_9 : exninst*}: + `%`({TAGS var_0, GLOBALS var_1, MEMS var_2, TABLES var_3, FUNCS var_4, DATAS var_5, ELEMS var_6, STRUCTS var_7, ARRAYS var_8, EXNS var_9}) + -- (wf_taginst: `%`(var_0))*{var_0 <- var_0} + -- (wf_globalinst: `%`(var_1))*{var_1 <- var_1} + -- (wf_meminst: `%`(var_2))*{var_2 <- var_2} + -- (wf_tableinst: `%`(var_3))*{var_3 <- var_3} + -- (wf_funcinst: `%`(var_4))*{var_4 <- var_4} + -- (wf_datainst: `%`(var_5))*{var_5 <- var_5} + -- (wf_eleminst: `%`(var_6))*{var_6 <- var_6} + -- (wf_structinst: `%`(var_7))*{var_7 <- var_7} + -- (wf_arrayinst: `%`(var_8))*{var_8 <- var_8} + -- (wf_exninst: `%`(var_9))*{var_9 <- var_9} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax state = + | `%;%`(store : store, frame : frame) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_state: `%`(state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule state_case_0{store : store, frame : frame}: + `%`(`%;%`_state(store, frame)) + -- wf_store: `%`(store) + -- wf_frame: `%`(frame) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +syntax config = + | `%;%`(state : state, `instr*` : instr*) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation wf_config: `%`(config) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule config_case_0{state : state, `instr*` : instr*}: + `%`(`%;%`_config(state, `instr*`)) + -- wf_state: `%`(state) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $Ki : nat + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $Ki = 1024 + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $packfield_(storagetype : storagetype, val : val) : fieldval? + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(BOT_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{`null?` : null?, heaptype : heaptype, val : val}(REF_storagetype(`null?`, heaptype), val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(V128_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(F64_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(F32_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(I64_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{val : val}(I32_storagetype, val) = ?($fieldval_val(val)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() + -- otherwise + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(storagetype : storagetype, val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{storagetype : storagetype, val : val, ret_val : fieldval}: + `%%%`(storagetype, val, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_val: `%`(val) + -- if (ret_val = !($packfield_(storagetype, val))) + -- if ($packfield_(storagetype, val) =/= ?()) + -- wf_fieldval: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{ref : ref}(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) = ?(`REF.EXTERN`_val(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{hostaddr : hostaddr}(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) = ?(`REF.HOST_ADDR`_val(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{exnaddr : exnaddr}(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) = ?(`REF.EXN_ADDR`_val(exnaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{funcaddr : funcaddr}(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) = ?(`REF.FUNC_ADDR`_val(funcaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{arrayaddr : arrayaddr}(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(arrayaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{structaddr : structaddr}(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) = ?(`REF.STRUCT_ADDR`_val(structaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{`null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{u31 : u31}(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) = ?(`REF.I31_NUM`_val(u31)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(BOT_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(V128_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(F64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(F32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(I64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{vectype : vectype, var_1 : vec_}(I32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) = ?(VCONST_val(vectype, var_1)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(BOT_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_, `null?` : null?, heaptype : heaptype}(REF_storagetype(`null?`, heaptype), ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(V128_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(F64_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(F32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(I64_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) = ?(CONST_val(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{sx : sx, i : uN}(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, sx, i)))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $unpackfield_{sx : sx, i : uN}(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) + def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() + -- otherwise + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{storagetype : storagetype, var_0 : sx?, fieldval : fieldval, ret_val : val}: + `%%%%`(storagetype, var_0, fieldval, ret_val) + -- wf_storagetype: `%`(storagetype) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = !($unpackfield_(storagetype, var_0, fieldval))) + -- if ($unpackfield_(storagetype, var_0, fieldval) =/= ?()) + -- wf_val: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 +relation fun_tagsxa: `%%`(externaddr*, tagaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([TAG_externaddr(a)] ++ xa#1*{xa#1 <- `xa*`}, [a] ++ var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tagaddr*}: + `%%`([externaddr] ++ xa#2*{xa#2 <- `xa*`}, var_0) + -- fun_tagsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_funcinst: `%`(funcinst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funcinst_case_{var_0 : deftype, var_1 : moduleinst, var_2 : funccode}: - `%`({TYPE var_0, MODULE var_1, CODE var_2}) - -- wf_moduleinst: `%`(var_1) - -- wf_funccode: `%`(var_2) +rec { + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 +relation fun_globalsxa: `%%`(externaddr*, globaladdr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([GLOBAL_externaddr(a)] ++ xa#3*{xa#3 <- `xa*`}, [a] ++ var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : globaladdr*}: + `%%`([externaddr] ++ xa#4*{xa#4 <- `xa*`}, var_0) + -- fun_globalsxa: `%%`(xa*{xa <- `xa*`}, var_0) +} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax datainst = -{ - BYTES byte* +rec { + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 +relation fun_memsxa: `%%`(externaddr*, memaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([MEM_externaddr(a)] ++ xa#5*{xa#5 <- `xa*`}, [a] ++ var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : memaddr*}: + `%%`([externaddr] ++ xa#6*{xa#6 <- `xa*`}, var_0) + -- fun_memsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_datainst: `%`(datainst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule datainst_case_{var_0 : byte*}: - `%`({BYTES var_0}) - -- (wf_byte: `%`(var_0))*{var_0 <- var_0} +rec { + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 +relation fun_tablesxa: `%%`(externaddr*, tableaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_1{a : nat, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([TABLE_externaddr(a)] ++ xa#7*{xa#7 <- `xa*`}, [a] ++ var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : tableaddr*}: + `%%`([externaddr] ++ xa#8*{xa#8 <- `xa*`}, var_0) + -- fun_tablesxa: `%%`(xa*{xa <- `xa*`}, var_0) +} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax eleminst = -{ - TYPE elemtype, - REFS ref* +rec { + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 +relation fun_funcsxa: `%%`(externaddr*, funcaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_1{a : nat, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([FUNC_externaddr(a)] ++ xa#9*{xa#9 <- `xa*`}, [a] ++ var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_2{externaddr : externaddr, `xa*` : externaddr*, var_0 : funcaddr*}: + `%%`([externaddr] ++ xa#10*{xa#10 <- `xa*`}, var_0) + -- fun_funcsxa: `%%`(xa*{xa <- `xa*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_eleminst: `%`(eleminst) +def $store(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule eleminst_case_{var_0 : elemtype, var_1 : ref*}: - `%`({TYPE var_0, REFS var_1}) - -- wf_reftype: `%`(var_0) - -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + def $store{s : store, f : frame}(`%;%`_state(s, f)) = s ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax packval = - | PACK(packtype : packtype, iN) +relation store_is_wf: `%%`(state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $store(state)) + -- wf_store: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_packval: `%`(packval) +def $frame(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule packval_case_0{packtype : packtype, var_0 : iN}: - `%`(PACK_packval(packtype, var_0)) - -- wf_uN: `%%`($psize(packtype), var_0) + def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax fieldval = - | CONST(numtype : numtype, num_) - | VCONST(vectype : vectype, vec_) - | `REF.I31_NUM`(u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(structaddr : structaddr) - | `REF.ARRAY_ADDR`(arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(funcaddr : funcaddr) - | `REF.EXN_ADDR`(exnaddr : exnaddr) - | `REF.HOST_ADDR`(hostaddr : hostaddr) - | `REF.EXTERN`(ref : ref) - | PACK(packtype : packtype, iN) +relation frame_is_wf: `%%`(state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $frame(state)) + -- wf_frame: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_fieldval: `%`(fieldval) +def $tagaddr(state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_0{numtype : numtype, var_0 : num_}: - `%`(CONST_fieldval(numtype, var_0)) - -- wf_num_: `%%`(numtype, var_0) + def $tagaddr{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame.TAGS_moduleinst +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $moduleinst(state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_1{vectype : vectype, var_0 : vec_}: - `%`(VCONST_fieldval(vectype, var_0)) - -- wf_uN: `%%`($vsize(vectype), var_0) + def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(state : state, ret_val : moduleinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_2{u31 : u31}: - `%`(`REF.I31_NUM`_fieldval(u31)) - -- wf_uN: `%%`(31, u31) + rule moduleinst_is_wf_0{state : state, ret_val : moduleinst}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $moduleinst(state)) + -- wf_moduleinst: `%`(ret_val) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $taginst(state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_3: - `%`(`REF.NULL_ADDR`_fieldval) + def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(state : state, ret_val : taginst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_4{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_fieldval(structaddr)) + rule taginst_is_wf_0{state : state, ret_val : taginst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $taginst(state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $globalinst(state : state) : globalinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_5{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_fieldval(arrayaddr)) + def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(state : state, ret_val : globalinst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_6{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_fieldval(funcaddr)) + rule globalinst_is_wf_0{state : state, ret_val : globalinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $globalinst(state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $meminst(state : state) : meminst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_7{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_fieldval(exnaddr)) + def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(state : state, ret_val : meminst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_8{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(hostaddr)) + rule meminst_is_wf_0{state : state, ret_val : meminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $meminst(state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $tableinst(state : state) : tableinst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_9{ref : ref}: - `%`(`REF.EXTERN`_fieldval(ref)) - -- wf_ref: `%`(ref) + def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(state : state, ret_val : tableinst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_10{packtype : packtype, var_0 : iN}: - `%`(PACK_fieldval(packtype, var_0)) - -- wf_uN: `%%`($psize(packtype), var_0) + rule tableinst_is_wf_0{state : state, ret_val : tableinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $tableinst(state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structinst = -{ - TYPE deftype, - FIELDS fieldval* -} +def $funcinst(state : state) : funcinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_structinst: `%`(structinst) +relation funcinst_is_wf: `%%`(state : state, ret_val : funcinst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule structinst_case_{var_0 : deftype, var_1 : fieldval*}: - `%`({TYPE var_0, FIELDS var_1}) - -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} + rule funcinst_is_wf_0{state : state, ret_val : funcinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $funcinst(state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayinst = -{ - TYPE deftype, - FIELDS fieldval* -} +def $datainst(state : state) : datainst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_arrayinst: `%`(arrayinst) +relation datainst_is_wf: `%%`(state : state, ret_val : datainst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule arrayinst_case_{var_0 : deftype, var_1 : fieldval*}: - `%`({TYPE var_0, FIELDS var_1}) - -- (wf_fieldval: `%`(var_1))*{var_1 <- var_1} + rule datainst_is_wf_0{state : state, ret_val : datainst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $datainst(state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exninst = -{ - TAG tagaddr, - FIELDS val* -} +def $eleminst(state : state) : eleminst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_exninst: `%`(exninst) +relation eleminst_is_wf: `%%`(state : state, ret_val : eleminst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule exninst_case_{var_0 : tagaddr, var_1 : val*}: - `%`({TAG var_0, FIELDS var_1}) - -- (wf_val: `%`(var_1))*{var_1 <- var_1} + rule eleminst_is_wf_0{state : state, ret_val : eleminst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $eleminst(state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax store = -{ - TAGS taginst*, - GLOBALS globalinst*, - MEMS meminst*, - TABLES tableinst*, - FUNCS funcinst*, - DATAS datainst*, - ELEMS eleminst*, - STRUCTS structinst*, - ARRAYS arrayinst*, - EXNS exninst* -} +def $structinst(state : state) : structinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_store: `%`(store) +relation structinst_is_wf: `%%`(state : state, ret_val : structinst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule store_case_{var_0 : taginst*, var_1 : globalinst*, var_2 : meminst*, var_3 : tableinst*, var_4 : funcinst*, var_5 : datainst*, var_6 : eleminst*, var_7 : structinst*, var_8 : arrayinst*, var_9 : exninst*}: - `%`({TAGS var_0, GLOBALS var_1, MEMS var_2, TABLES var_3, FUNCS var_4, DATAS var_5, ELEMS var_6, STRUCTS var_7, ARRAYS var_8, EXNS var_9}) - -- (wf_taginst: `%`(var_0))*{var_0 <- var_0} - -- (wf_globalinst: `%`(var_1))*{var_1 <- var_1} - -- (wf_meminst: `%`(var_2))*{var_2 <- var_2} - -- (wf_tableinst: `%`(var_3))*{var_3 <- var_3} - -- (wf_funcinst: `%`(var_4))*{var_4 <- var_4} - -- (wf_datainst: `%`(var_5))*{var_5 <- var_5} - -- (wf_eleminst: `%`(var_6))*{var_6 <- var_6} - -- (wf_structinst: `%`(var_7))*{var_7 <- var_7} - -- (wf_arrayinst: `%`(var_8))*{var_8 <- var_8} - -- (wf_exninst: `%`(var_9))*{var_9 <- var_9} + rule structinst_is_wf_0{state : state, ret_val : structinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $structinst(state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax state = - | `%;%`(store : store, frame : frame) +def $arrayinst(state : state) : arrayinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_state: `%`(state) +relation arrayinst_is_wf: `%%`(state : state, ret_val : arrayinst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule state_case_0{store : store, frame : frame}: - `%`(`%;%`_state(store, frame)) - -- wf_store: `%`(store) - -- wf_frame: `%`(frame) + rule arrayinst_is_wf_0{state : state, ret_val : arrayinst*}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $arrayinst(state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax config = - | `%;%`(state : state, `instr*` : instr*) +def $exninst(state : state) : exninst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -relation wf_config: `%`(config) +relation exninst_is_wf: `%%`(state : state, ret_val : exninst*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule config_case_0{state : state, `instr*` : instr*}: - `%`(`%;%`_config(state, `instr*`)) + rule exninst_is_wf_0{state : state, ret_val : exninst*}: + `%%`(state, ret_val) -- wf_state: `%`(state) - -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- if (ret_val = $exninst(state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $Ki : nat +def $fof(state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 + def $fof{z : state}(z) = $frame(z) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $packfield_(storagetype : storagetype, val : val) : fieldval? +relation fof_is_wf: `%%`(state : state, ret_val : frame) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), val) = ?((val : val <: fieldval)) + rule fof_is_wf_0{state : state, ret_val : frame}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $fof(state)) + -- wf_frame: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $type(state : state, typeidx : typeidx) : deftype ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{packtype : packtype, i : uN}((packtype : packtype <: storagetype), CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(packtype, $wrap__(32, $psize(packtype), i))) - def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() - -- otherwise + def $type{z : state, x : uN}(z, x) = $fof(z).MODULE_frame.TYPES_moduleinst[$proj_uN_0(x).0] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? +def $sof(state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{valtype : valtype, val : val}((valtype : valtype <: storagetype), ?(), (val : val <: fieldval)) = ?(val) + def $sof{z : state}(z) = $store(z) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(state : state, ret_val : store) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{packtype : packtype, sx : sx, i : uN}((packtype : packtype <: storagetype), ?(sx), PACK_fieldval(packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(packtype), 32, sx, i)))) - def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() - -- otherwise + rule sof_is_wf_0{state : state, ret_val : store}: + `%%`(state, ret_val) + -- wf_state: `%`(state) + -- if (ret_val = $sof(state)) + -- wf_store: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { +def $tag(state : state, tagidx : tagidx) : taginst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.1-190.86 -def $tagsxa(externaddr*) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:196.1-196.23 - def $tagsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:197.1-197.42 - def $tagsxa{a : nat, `xa*` : externaddr*}([TAG_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tagsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:198.1-198.57 - def $tagsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tagsxa(xa*{xa <- `xa*`}) -} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(state : state, tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{state : state, tagidx : tagidx, ret_val : taginst}: + `%%%`(state, tagidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tagidx) + -- if (ret_val = $tag(state, tagidx)) + -- wf_taginst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { +def $global(state : state, globalidx : globalidx) : globalinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.1-191.89 -def $globalsxa(externaddr*) : globaladdr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:200.1-200.26 - def $globalsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:201.1-201.51 - def $globalsxa{a : nat, `xa*` : externaddr*}([GLOBAL_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $globalsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:202.1-202.63 - def $globalsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $globalsxa(xa*{xa <- `xa*`}) -} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(state : state, globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{state : state, globalidx : globalidx, ret_val : globalinst}: + `%%%`(state, globalidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- if (ret_val = $global(state, globalidx)) + -- wf_globalinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { +def $mem(state : state, memidx : memidx) : meminst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.1-192.86 -def $memsxa(externaddr*) : memaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:204.1-204.23 - def $memsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:205.1-205.42 - def $memsxa{a : nat, `xa*` : externaddr*}([MEM_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $memsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:206.1-206.57 - def $memsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $memsxa(xa*{xa <- `xa*`}) -} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(state : state, memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{state : state, memidx : memidx, ret_val : meminst}: + `%%%`(state, memidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- if (ret_val = $mem(state, memidx)) + -- wf_meminst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { +def $table(state : state, tableidx : tableidx) : tableinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.1-193.88 -def $tablesxa(externaddr*) : tableaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:208.1-208.25 - def $tablesxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:209.1-209.48 - def $tablesxa{a : nat, `xa*` : externaddr*}([TABLE_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $tablesxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:210.1-210.61 - def $tablesxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $tablesxa(xa*{xa <- `xa*`}) -} +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{state : state, tableidx : tableidx, ret_val : tableinst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $table(state, tableidx)) + -- wf_tableinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -rec { - -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.1-194.87 -def $funcsxa(externaddr*) : funcaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:212.1-212.24 - def $funcsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:213.1-213.45 - def $funcsxa{a : nat, `xa*` : externaddr*}([FUNC_externaddr(a)] ++ xa*{xa <- `xa*`}) = [a] ++ $funcsxa(xa*{xa <- `xa*`}) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:214.1-214.59 - def $funcsxa{externaddr : externaddr, `xa*` : externaddr*}([externaddr] ++ xa*{xa <- `xa*`}) = $funcsxa(xa*{xa <- `xa*`}) -} +def $func(state : state, funcidx : funcidx) : funcinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $store(state : state) : store +relation func_is_wf: `%%%`(state : state, funcidx : funcidx, ret_val : funcinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $store{s : store, f : frame}(`%;%`_state(s, f)) = s + rule func_is_wf_0{state : state, funcidx : funcidx, ret_val : funcinst}: + `%%%`(state, funcidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, funcidx) + -- if (ret_val = $func(state, funcidx)) + -- wf_funcinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $frame(state : state) : frame +def $data(state : state, dataidx : dataidx) : datainst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $frame{s : store, f : frame}(`%;%`_state(s, f)) = f + def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tagaddr(state : state) : tagaddr* +relation data_is_wf: `%%%`(state : state, dataidx : dataidx, ret_val : datainst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tagaddr{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame.TAGS_moduleinst + rule data_is_wf_0{state : state, dataidx : dataidx, ret_val : datainst}: + `%%%`(state, dataidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- if (ret_val = $data(state, dataidx)) + -- wf_datainst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $moduleinst(state : state) : moduleinst +def $elem(state : state, tableidx : tableidx) : eleminst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame + def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $taginst(state : state) : taginst* +relation elem_is_wf: `%%%`(state : state, tableidx : tableidx, ret_val : eleminst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store + rule elem_is_wf_0{state : state, tableidx : tableidx, ret_val : eleminst}: + `%%%`(state, tableidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- if (ret_val = $elem(state, tableidx)) + -- wf_eleminst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $globalinst(state : state) : globalinst* +def $local(state : state, localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store + def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $meminst(state : state) : meminst* +relation local_is_wf: `%%%`(state : state, localidx : localidx, ret_val : val?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store + rule local_is_wf_0{state : state, localidx : localidx, ret_val : val?}: + `%%%`(state, localidx, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- if (ret_val = $local(state, localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tableinst(state : state) : tableinst* +def $with_local(state : state, localidx : localidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store + def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $funcinst(state : state) : funcinst* +relation with_local_is_wf: `%%%%`(state : state, localidx : localidx, val : val, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store + rule with_local_is_wf_0{state : state, localidx : localidx, val : val, ret_val : state}: + `%%%%`(state, localidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, localidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_local(state, localidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $datainst(state : state) : datainst* +def $with_global(state : state, globalidx : globalidx, val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store + def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $eleminst(state : state) : eleminst* +relation with_global_is_wf: `%%%%`(state : state, globalidx : globalidx, val : val, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store + rule with_global_is_wf_0{state : state, globalidx : globalidx, val : val, ret_val : state}: + `%%%%`(state, globalidx, val, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, globalidx) + -- wf_val: `%`(val) + -- if (ret_val = $with_global(state, globalidx, val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $structinst(state : state) : structinst* +def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store + def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $arrayinst(state : state) : arrayinst* +relation with_table_is_wf: `%%%%%`(state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store + rule with_table_is_wf_0{state : state, tableidx : tableidx, nat : nat, ref : ref, ret_val : state}: + `%%%%%`(state, tableidx, nat, ref, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_ref: `%`(ref) + -- if (ret_val = $with_table(state, tableidx, nat, ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $exninst(state : state) : exninst* +def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store + def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fof(state : state) : frame +relation with_tableinst_is_wf: `%%%%`(state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fof{z : state}(z) = $frame(z) + rule with_tableinst_is_wf_0{state : state, tableidx : tableidx, tableinst : tableinst, ret_val : state}: + `%%%%`(state, tableidx, tableinst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, tableidx) + -- wf_tableinst: `%`(tableinst) + -- if (ret_val = $with_tableinst(state, tableidx, tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $type(state : state, typeidx : typeidx) : deftype +def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $type{z : state, x : uN}(z, x) = $fof(z).MODULE_frame.TYPES_moduleinst[x!`%`_uN.0] + def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b#1*{b#1 <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $sof(state : state) : store +relation with_mem_is_wf: `%%%%%%`(state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $sof{z : state}(z) = $store(z) + rule with_mem_is_wf_0{state : state, memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(state, memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(state, memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $tag(state : state, tagidx : tagidx) : taginst +def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[x!`%`_uN.0]] + def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $global(state : state, globalidx : globalidx) : globalinst +relation with_meminst_is_wf: `%%%%`(state : state, memidx : memidx, meminst : meminst, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]] + rule with_meminst_is_wf_0{state : state, memidx : memidx, meminst : meminst, ret_val : state}: + `%%%%`(state, memidx, meminst, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, memidx) + -- wf_meminst: `%`(meminst) + -- if (ret_val = $with_meminst(state, memidx, meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $mem(state : state, memidx : memidx) : meminst +def $with_elem(state : state, elemidx : elemidx, ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] + def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r#1*{r#1 <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $table(state : state, tableidx : tableidx) : tableinst +relation with_elem_is_wf: `%%%%`(state : state, elemidx : elemidx, var_0 : ref*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] + rule with_elem_is_wf_0{state : state, elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(state, elemidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(state, elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $func(state : state, funcidx : funcidx) : funcinst +def $with_data(state : state, dataidx : dataidx, byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[x!`%`_uN.0]] + def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b#2*{b#2 <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $data(state : state, dataidx : dataidx) : datainst +relation with_data_is_wf: `%%%%`(state : state, dataidx : dataidx, var_0 : byte*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]] + rule with_data_is_wf_0{state : state, dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(state, dataidx, var_0, ret_val) + -- wf_state: `%`(state) + -- wf_uN: `%%`(32, dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(state, dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $elem(state : state, tableidx : tableidx) : eleminst +def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]] + def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $local(state : state, localidx : localidx) : val? +relation with_struct_is_wf: `%%%%%`(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[x!`%`_uN.0] + rule with_struct_is_wf_0{state : state, structaddr : structaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, structaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_struct(state, structaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_local(state : state, localidx : localidx, val : val) : state +def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[x!`%`_uN.0] = ?(v)])) + def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_global(state : state, globalidx : globalidx, val : val) : state +relation with_array_is_wf: `%%%%%`(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[x!`%`_uN.0]].VALUE_globalinst = v], $fof(z))) + rule with_array_is_wf_0{state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval, ret_val : state}: + `%%%%%`(state, arrayaddr, nat, fieldval, ret_val) + -- wf_state: `%`(state) + -- wf_fieldval: `%`(fieldval) + -- if (ret_val = $with_array(state, arrayaddr, nat, fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state +def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]].REFS_tableinst[i] = r], $fof(z))) + def $add_structinst{z : state, `si*` : structinst*}(z, si#1*{si#1 <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state +relation add_structinst_is_wf: `%%%`(state : state, var_0 : structinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[x!`%`_uN.0]] = ti], $fof(z))) + rule add_structinst_is_wf_0{state : state, var_0 : structinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state +def $add_arrayinst(state : state, arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_mem{z : state, x : uN, i : nat, j : nat, `b*` : byte*}(z, x, i, j, b*{b <- `b*`}) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]].BYTES_meminst[i : j] = b*{b <- `b*`}], $fof(z))) + def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai#1*{ai#1 <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state +relation add_arrayinst_is_wf: `%%%`(state : state, var_0 : arrayinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[x!`%`_uN.0]] = mi], $fof(z))) + rule add_arrayinst_is_wf_0{state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_elem(state : state, elemidx : elemidx, ref*) : state +def $add_exninst(state : state, exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_elem{z : state, x : uN, `r*` : ref*}(z, x, r*{r <- `r*`}) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[x!`%`_uN.0]].REFS_eleminst = r*{r <- `r*`}], $fof(z))) + def $add_exninst{z : state, `exn*` : exninst*}(z, exn#1*{exn#1 <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_data(state : state, dataidx : dataidx, byte*) : state +relation add_exninst_is_wf: `%%%`(state : state, var_0 : exninst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, `b*` : byte*}(z, x, b*{b <- `b*`}) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[x!`%`_uN.0]].BYTES_datainst = b*{b <- `b*`}], $fof(z))) + rule add_exninst_is_wf_0{state : state, var_0 : exninst*, ret_val : state}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state +relation fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%`(tableinst, n, r) + -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_array(state : state, arrayaddr : arrayaddr, nat : nat, fieldval : fieldval) : state +relation fun_growtable: `%%%%`(tableinst, nat, ref, tableinst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}} = tableinst + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#3*{r'#3 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#5?{j#5 <- `j?`}), rt), REFS r'#5*{r'#5 <- `r'*`} ++ r^n{}}) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_structinst(state : state, structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_structinst{z : state, `si*` : structinst*}(z, si*{si <- `si*`}) = `%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si*{si <- `si*`}], $fof(z))) + rule fun_growtable_case_1{x0 : tableinst, x1 : nat, x2 : ref}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_growtable_before_fun_growtable_case_1: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_arrayinst(state : state, arrayinst*) : state +relation growtable_is_wf: `%%%%`(tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_arrayinst{z : state, `ai*` : arrayinst*}(z, ai*{ai <- `ai*`}) = `%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai*{ai <- `ai*`}], $fof(z))) + rule growtable_is_wf_0{tableinst : tableinst, nat : nat, ref : ref, ret_val : tableinst, var_0 : tableinst?}: + `%%%%`(tableinst, nat, ref, ret_val) + -- wf_tableinst: `%`(tableinst) + -- wf_ref: `%`(ref) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(ret_val) + -- fun_growtable: `%%%%`(tableinst, nat, ref, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_exninst(state : state, exninst*) : state +relation fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_exninst{z : state, `exn*` : exninst*}(z, exn*{exn <- `exn*`}) = `%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn*{exn <- `exn*`}], $fof(z))) + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%`(meminst, n) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? +relation fun_growmem: `%%%`(meminst, nat, meminst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, i' : uN}(tableinst, n, r) = ?(tableinst') - -- let{at : addrtype, i : u64, `j?` : u64?, rt : reftype, `r'*` : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}} = tableinst - -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - -- if (i'!`%`_uN.0 = (|r'*{r' <- `r'*`}| + n)) - -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} - -- if ((i'!`%`_uN.0 : nat <:> int) <= (((2 ^ $size((at : addrtype <: numtype))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`} ++ r^n{}}) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#3*{b#3 <- `b*`}} = meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#4*{b#4 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#5*{b#5 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#9?{j#9 <- `j?`})), BYTES b#6*{b#6 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#10?{j#10 <- `j?`})), BYTES b#7*{b#7 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_1{x0 : meminst, x1 : nat}: + `%%%`(x0, x1, ?()) + -- ~ fun_growmem_before_fun_growmem_case_1: `%%`(x0, x1) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(meminst : meminst, nat : nat) : meminst? +relation growmem_is_wf: `%%%`(meminst : meminst, nat : nat, ret_val : meminst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{meminst : meminst, n : nat, meminst' : meminst, i' : uN}(meminst, n) = ?(meminst') - -- let{at : addrtype, i : u64, `j?` : u64?, `b*` : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}} = meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - -- if ((i'!`%`_uN.0 : nat <:> rat) = (((|b*{b <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) - -- (if (i'!`%`_uN.0 <= j!`%`_uN.0))?{j <- `j?`} - -- if (i'!`%`_uN.0 <= (2 ^ ((($size((at : addrtype <: numtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j?{j <- `j?`})), BYTES b*{b <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + rule growmem_is_wf_0{meminst : meminst, nat : nat, ret_val : meminst, var_0 : meminst?}: + `%%%`(meminst, nat, ret_val) + -- wf_meminst: `%`(meminst) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(ret_val) + -- fun_growmem: `%%%`(meminst, nat, var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -9347,32 +16286,36 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) + `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) + -- if (a < |s.STRUCTS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) + `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) + -- if (a < |s.ARRAYS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), (dt : deftype <: heaptype))) + `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) -- if (s.EXNS_store[a] = exn) + -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) @@ -9413,21 +16356,21 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) relation Val_ok: `%|-%:%`(store, val, valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule num{s : store, num : num, nt : numtype}: - `%|-%:%`(s, (num : num <: val), (nt : numtype <: valtype)) + `%|-%:%`(s, $val_num(num), $valtype_numtype(nt)) -- Num_ok: `%|-%:%`(s, num, nt) -- wf_store: `%`(s) -- wf_num: `%`(num) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule vec{s : store, vec : vec, vt : vectype}: - `%|-%:%`(s, (vec : vec <: val), (vt : vectype <: valtype)) + `%|-%:%`(s, $val_vec(vec), $valtype_vectype(vt)) -- Vec_ok: `%|-%:%`(s, vec, vt) -- wf_store: `%`(s) -- wf_vec: `%`(vec) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule ref{s : store, ref : ref, rt : reftype}: - `%|-%:%`(s, (ref : ref <: val), (rt : reftype <: valtype)) + `%|-%:%`(s, $val_ref(ref), $valtype_reftype(rt)) -- Ref_ok: `%|-%:%`(s, ref, rt) -- wf_store: `%`(s) -- wf_ref: `%`(ref) @@ -9445,7 +16388,7 @@ relation Packval_ok: `%|-%:%`(store, packval, packtype) relation Fieldval_ok: `%|-%:%`(store, fieldval, storagetype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule val{s : store, val : val, t : valtype}: - `%|-%:%`(s, (val : val <: fieldval), (t : valtype <: storagetype)) + `%|-%:%`(s, $fieldval_val(val), $storagetype_valtype(t)) -- Val_ok: `%|-%:%`(s, val, t) -- wf_store: `%`(s) -- wf_val: `%`(val) @@ -9453,7 +16396,7 @@ relation Fieldval_ok: `%|-%:%`(store, fieldval, storagetype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule packval{s : store, packval : packval, pt : packtype}: - `%|-%:%`(s, (packval : packval <: fieldval), (pt : packtype <: storagetype)) + `%|-%:%`(s, $fieldval_packval(packval), $storagetype_packtype(pt)) -- Packval_ok: `%|-%:%`(s, packval, pt) -- wf_store: `%`(s) -- wf_packval: `%`(packval) @@ -9467,6 +16410,7 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) rule tag{s : store, a : addr, taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) -- if (s.TAGS_store[a] = taginst) + -- if (a < |s.TAGS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) @@ -9474,6 +16418,7 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) rule global{s : store, a : addr, globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) -- if (s.GLOBALS_store[a] = globalinst) + -- if (a < |s.GLOBALS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) @@ -9481,6 +16426,7 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) rule mem{s : store, a : addr, meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) -- if (s.MEMS_store[a] = meminst) + -- if (a < |s.MEMS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) @@ -9488,15 +16434,17 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) rule table{s : store, a : addr, tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) -- if (s.TABLES_store[a] = tableinst) + -- if (a < |s.TABLES_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, funcinst : funcinst}: - `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) + `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) -- if (s.FUNCS_store[a] = funcinst) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) - -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:126.1-130.37 rule sub{s : store, externaddr : externaddr, xt : externtype, xt' : externtype}: @@ -9511,100 +16459,100 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) } ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_valtype(moduleinst : moduleinst, valtype : valtype) : valtype +relation fun_inst_valtype: `%%%`(moduleinst, valtype, valtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_valtype{moduleinst : moduleinst, t : valtype}(moduleinst, t) = $subst_all_valtype(t, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule fun_inst_valtype_case_0{moduleinst : moduleinst, t : valtype, var_0 : valtype}: + `%%%`(moduleinst, t, var_0) + -- fun_subst_all_valtype: `%%%`(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_reftype(moduleinst : moduleinst, reftype : reftype) : reftype +relation inst_valtype_is_wf: `%%%`(moduleinst : moduleinst, valtype : valtype, ret_val : valtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_reftype{moduleinst : moduleinst, rt : reftype}(moduleinst, rt) = $subst_all_reftype(rt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule inst_valtype_is_wf_0{moduleinst : moduleinst, valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(moduleinst, valtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_valtype: `%`(valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_inst_valtype: `%%%`(moduleinst, valtype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype +relation fun_inst_reftype: `%%%`(moduleinst, reftype, reftype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_globaltype{moduleinst : moduleinst, gt : globaltype}(moduleinst, gt) = $subst_all_globaltype(gt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule fun_inst_reftype_case_0{moduleinst : moduleinst, rt : reftype, var_0 : reftype}: + `%%%`(moduleinst, rt, var_0) + -- fun_subst_all_reftype: `%%%`(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype +relation inst_reftype_is_wf: `%%%`(moduleinst : moduleinst, reftype : reftype, ret_val : reftype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{moduleinst : moduleinst, mt : memtype}(moduleinst, mt) = $subst_all_memtype(mt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule inst_reftype_is_wf_0{moduleinst : moduleinst, reftype : reftype, ret_val : reftype, var_0 : reftype}: + `%%%`(moduleinst, reftype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_reftype: `%`(reftype) + -- if (ret_val = var_0) + -- wf_reftype: `%`(ret_val) + -- fun_inst_reftype: `%%%`(moduleinst, reftype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype +relation fun_inst_globaltype: `%%%`(moduleinst, globaltype, globaltype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_tabletype{moduleinst : moduleinst, tt : tabletype}(moduleinst, tt) = $subst_all_tabletype(tt, (moduleinst.TYPES_moduleinst : deftype* <: typeuse*)) + rule fun_inst_globaltype_case_0{moduleinst : moduleinst, gt : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, gt, var_0) + -- fun_subst_all_globaltype: `%%%`(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- moduleinst.TYPES_moduleinst}, var_0) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_br_on_null-addr`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_null-null_0`{val : val, l : labelidx}: - `%`([(val : val <: instr) BR_ON_NULL_instr(l)]) - -- if (val = `REF.NULL_ADDR`_val) - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NULL_instr(l)) - -- wf_instr: `%`(BR_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{moduleinst : moduleinst, globaltype : globaltype, ret_val : globaltype, var_0 : globaltype}: + `%%%`(moduleinst, globaltype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_globaltype: `%`(globaltype) + -- if (ret_val = var_0) + -- wf_globaltype: `%`(ret_val) + -- fun_inst_globaltype: `%%%`(moduleinst, globaltype, var_0) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_br_on_non_null-addr`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_non_null-null_0`{val : val, l : labelidx}: - `%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)]) - -- if (val = `REF.NULL_ADDR`_val) - -- wf_val: `%`(val) - -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_memtype: `%%%`(moduleinst, memtype, memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_memtype_case_0{moduleinst : moduleinst, mt : memtype, var_0 : memtype}: + `%%%`(moduleinst, mt, var_0) + -- fun_subst_all_memtype: `%%%`(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- moduleinst.TYPES_moduleinst}, var_0) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_ref.is_null-false`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.is_null-true_0`{ref : ref}: - `%`([(ref : ref <: instr) `REF.IS_NULL`_instr]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_memtype_is_wf: `%%%`(moduleinst : moduleinst, memtype : memtype, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_memtype_is_wf_0{moduleinst : moduleinst, memtype : memtype, ret_val : memtype, var_0 : memtype}: + `%%%`(moduleinst, memtype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_memtype: `%`(ret_val) + -- fun_inst_memtype: `%%%`(moduleinst, memtype, var_0) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_ref.as_non_null-addr`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.as_non_null-null_0`{ref : ref}: - `%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - -- wf_instr: `%`(TRAP_instr) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_tabletype: `%%%`(moduleinst, tabletype, tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_tabletype_case_0{moduleinst : moduleinst, tt : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tt, var_0) + -- fun_subst_all_tabletype: `%%%`(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_tabletype_is_wf: `%%%`(moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_tabletype_is_wf_0{moduleinst : moduleinst, tabletype : tabletype, ret_val : tabletype, var_0 : tabletype}: + `%%%`(moduleinst, tabletype, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_tabletype: `%`(tabletype) + -- if (ret_val = var_0) + -- wf_tabletype: `%`(ret_val) + -- fun_inst_tabletype: `%%%`(moduleinst, tabletype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_pure_before_ref.eq-true`: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-null_0`{ref_1 : ref, ref_2 : ref}: - `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) - -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) - -- wf_ref: `%`(ref_1) - -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_ref.eq-false`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.eq-true_0`{ref_1 : ref, ref_2 : ref}: - `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) - -- ~ `Step_pure_before_ref.eq-true`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) - -- if (ref_1 = ref_2) - -- wf_ref: `%`(ref_1) - -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.eq-null_1`{ref_1 : ref, ref_2 : ref}: - `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) @@ -9612,16 +16560,6 @@ relation `Step_pure_before_ref.eq-false`: `%`(instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) -- wf_ref: `%`(`REF.NULL_ADDR`_ref) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_pure_before_extern.convert_any-addr`: `%`(instr*) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `extern.convert_any-null_0`{ref : ref}: - `%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr]) - -- if (ref = `REF.NULL_ADDR`_ref) - -- wf_ref: `%`(ref) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -9637,14 +16575,15 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule drop{val : val}: - `%~>%`([(val : val <: instr) DROP_instr], []) + `%~>%`([$instr_val(val) DROP_instr], []) -- wf_val: `%`(val) -- wf_instr: `%`(DROP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-true`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_1 : val <: instr)]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9652,8 +16591,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `select-false`{val_1 : val, val_2 : val, c : num_, `t*?` : valtype*?}: - `%~>%`([(val_1 : val <: instr) (val_2 : val <: instr) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [(val_2 : val <: instr)]) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_2)]) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9662,7 +16602,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-true`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) -- wf_instr: `%`(BLOCK_instr(bt, instr_1*{instr_1 <- `instr_1*`})) @@ -9670,39 +16611,42 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `if-false`{c : num_, bt : blocktype, `instr_1*` : instr*, `instr_2*` : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})], [BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})]) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1*{instr_1 <- `instr_1*`}, instr_2*{instr_2 <- `instr_2*`})) -- wf_instr: `%`(BLOCK_instr(bt, instr_2*{instr_2 <- `instr_2*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `label-vals`{n : n, `instr*` : instr*, `val*` : val*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, (val : val <: instr)*{val <- `val*`})) + `%~>%`([`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, $instr_val(val)*{val <- `val*`})], $instr_val(val)*{val <- `val*`}) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr*{instr <- `instr*`}, $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-zero`{n : n, `instr'*` : instr*, `val'*` : val*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) - -- if (l!`%`_uN.0 = 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`} ++ instr'*{instr' <- `instr'*`}) + -- if ($proj_uN_0(l).0 = 0) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-label-succ`{n : n, `instr'*` : instr*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(`%`_labelidx((((l!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) - -- if (l!`%`_uN.0 > 0) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) - -- wf_instr: `%`(BR_instr(`%`_labelidx((((l!`%`_uN.0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) + -- if ($proj_uN_0(l).0 > 0) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + -- wf_instr: `%`(BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br-handler`{n : n, `catch*` : catch*, `val*` : val*, l : labelidx, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-true`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if (!($proj_num__0(c))!`%`_uN.0 =/= 0) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) @@ -9710,29 +16654,32 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_if-false`{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if (!($proj_num__0(c))!`%`_uN.0 = 0) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-lt`{i : num_, `l*` : labelidx*, l' : labelidx}: - `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[!($proj_num__0(i))!`%`_uN.0])]) - -- if (!($proj_num__0(i))!`%`_uN.0 < |l*{l <- `l*`}|) + `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])]) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) - -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[!($proj_num__0(i))!`%`_uN.0])) + -- wf_instr: `%`(BR_instr(l*{l <- `l*`}[$proj_uN_0(!($proj_num__0(i))).0])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l*{l <- `l*`}, l')], [BR_instr(l')]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |l*{l <- `l*`}|) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l')) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [BR_instr(l)]) + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [BR_instr(l)]) -- if (val = `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) @@ -9741,14 +16688,14 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NULL_instr(l)], [(val : val <: instr)]) - -- ~ `Step_pure_before_br_on_null-addr`: `%`([(val : val <: instr) BR_ON_NULL_instr(l)]) + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [$instr_val(val)]) + -- if (val =/= `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_non_null-null`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], []) + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], []) -- if (val = `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) @@ -9756,58 +16703,60 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_non_null-addr`{val : val, l : labelidx}: - `%~>%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)], [(val : val <: instr) BR_instr(l)]) - -- ~ `Step_pure_before_br_on_non_null-addr`: `%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)]) + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], [$instr_val(val) BR_instr(l)]) + -- if (val =/= `REF.NULL_ADDR`_val) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call_indirect{x : idx, yy : typeuse}: - `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) CALL_REF_instr(yy)]) + `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) CALL_REF_instr(yy)]) -- wf_instr: `%`(CALL_INDIRECT_instr(x, yy)) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) + -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_indirect{x : idx, yy : typeuse}: - `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype))) RETURN_CALL_REF_instr(yy)]) + `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) RETURN_CALL_REF_instr(yy)]) -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, yy)) -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), (yy : typeuse <: heaptype)))) + -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `frame-vals`{n : n, f : frame, `val*` : val*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val : val <: instr)^n{val <- `val*`})) + `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})], $instr_val(val)^n{val <- `val*`}) + -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val)^n{val <- `val*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-frame`{n : n, f : frame, `val'*` : val*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)^n{val <- `val*`}) - -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)^n{val <- `val*`}) + -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-label`{n : n, `instr'*` : instr*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [RETURN_instr]) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(RETURN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return-handler`{n : n, `catch*` : catch*, `val*` : val*, `instr*` : instr*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr]) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})], $instr_val(val)*{val <- `val*`} ++ [RETURN_instr]) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(RETURN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `handler-vals`{n : n, `catch*` : catch*, `val*` : val*}: - `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})], (val : val <: instr)*{val <- `val*`}) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`})) + `%~>%`([`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`})], $instr_val(val)*{val <- `val*`}) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `trap-instrs`{`val*` : val*, `instr*` : instr*}: - `%~>%`((val : val <: instr)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) + `%~>%`($instr_val(val)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) -- (wf_val: `%`(val))*{val <- `val*`} -- (wf_instr: `%`(instr))*{instr <- `instr*`} @@ -9833,7 +16782,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.tee`{val : val, x : idx}: - `%~>%`([(val : val <: instr) `LOCAL.TEE`_instr(x)], [(val : val <: instr) (val : val <: instr) `LOCAL.SET`_instr(x)]) + `%~>%`([$instr_val(val) `LOCAL.TEE`_instr(x)], [$instr_val(val) $instr_val(val) `LOCAL.SET`_instr(x)]) -- wf_val: `%`(val) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) @@ -9844,10 +16793,11 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`REF.I31`_instr) -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.is_null-true`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) @@ -9856,15 +16806,15 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.is_null-false`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- ~ `Step_pure_before_ref.is_null-false`: `%`([(ref : ref <: instr) `REF.IS_NULL`_instr]) + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.as_non_null-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [TRAP_instr]) + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [TRAP_instr]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) @@ -9873,14 +16823,14 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.as_non_null-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr], [(ref : ref <: instr)]) - -- ~ `Step_pure_before_ref.as_non_null-addr`: `%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr]) + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [$instr_ref(ref)]) + -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-null`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) @@ -9890,8 +16840,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-true`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- ~ `Step_pure_before_ref.eq-true`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) -- if (ref_1 = ref_2) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) @@ -9900,8 +16850,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.eq-false`{ref_1 : ref, ref_2 : ref}: - `%~>%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- ~ `Step_pure_before_ref.eq-false`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + -- if (ref_1 =/= ref_2) + -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) -- wf_instr: `%`(`REF.EQ`_instr) @@ -9923,7 +16874,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new`{val : val, n : n, x : idx}: - `%~>%`([(val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW`_instr(x)], (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + `%~>%`([$instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW`_instr(x)], $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- wf_val: `%`(val) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) @@ -9931,7 +16882,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `extern.convert_any-null`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) -- if (ref = `REF.NULL_ADDR`_ref) -- wf_ref: `%`(ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) @@ -9939,8 +16890,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `extern.convert_any-addr`{ref : ref}: - `%~>%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) - -- ~ `Step_pure_before_extern.convert_any-addr`: `%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr]) + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) + -- if (ref =/= `REF.NULL_ADDR`_ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) @@ -9952,48 +16903,60 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `any.convert_extern-addr`{ref : ref}: - `%~>%`([`REF.EXTERN`_instr(ref) `ANY.CONVERT_EXTERN`_instr], [(ref : ref <: instr)]) + `%~>%`([`REF.EXTERN`_instr(ref) `ANY.CONVERT_EXTERN`_instr], [$instr_ref(ref)]) -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_}: + rule `unop-val`{nt : numtype, c_1 : num_, unop : unop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (c <- $unop_(nt, unop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_}: + rule `unop-trap`{nt : numtype, c_1 : num_, unop : unop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) - -- if ($unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: + rule `binop-val`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: + rule `binop-trap`{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) - -- if ($binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -10002,31 +16965,40 @@ relation Step_pure: `%~>%`(instr*, instr*) rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: + rule `cvtop-val`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (c <- $cvtop__(nt_1, nt_2, cvtop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: + rule `cvtop-trap`{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, vvunop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10035,6 +17007,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvbinop{c_1 : vec_, c_2 : vec_, vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, vvbinop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) @@ -10044,6 +17018,8 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, vvternop)], [VCONST_instr(V128_vectype, c)]) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -10054,123 +17030,159 @@ relation Step_pure: `%~>%`(instr*, instr*) rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: + rule `vunop-val`{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vunop_(sh, vunop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_}: + rule `vunop-trap`{c_1 : vec_, sh : shape, vunop : vunop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) - -- if ($vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: + rule `vbinop-val`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: + rule `vbinop-trap`{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: + rule `vternop-val`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: + rule `vternop-trap`{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) - -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) - -- if (!($proj_num__0(c))!`%`_uN.0 = $prod($inez_($jsizenn(Jnn), !($proj_lane__2(i)))!`%`_uN.0*{i <- `i*`})) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), i))*{i <- `i*`} + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, var_0 : nat}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) + -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) + -- if ($proj_num__0(c) =/= ?()) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(Jnn), !($proj_lane__2(i)))))*{i <- `i*`} + -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) + -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_vtestop__0_vtestop_(Jnn, M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- fun_prod: `%%`($proj_uN_0($inez_($jsizenn(Jnn), !($proj_lane__2(i)))).0*{i <- `i*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: + rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vrelop_: `%%%%%`(sh, vrelop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: + rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshiftop_: `%%%%%`(sh, vshiftop, c_1, !($proj_num__0(i)), var_0) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: + rule vbitmask{c_1 : vec_, sh : ishape, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) - -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- if (!($proj_num__0(c)) = var_0) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- fun_vbitmaskop_: `%%%`(sh, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: + rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vswizzlop_: `%%%%%`(sh, swizzlop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_}: + rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, `i*` : laneidx*, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i*{i <- `i*`})], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshufflop_: `%%%%%`(sh, i*{i <- `i*`}, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -10178,27 +17190,37 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-num`{c_1 : vec_, nt : numtype, M : M, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) + -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)|) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M)), ?(), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) - -- wf_shape: `%`(`%X%`_shape((nt : numtype <: lanetype), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) + -- wf_shape: `%`(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vextract_lane-pack`{c_1 : vec_, pt : packtype, M : M, sx : sx, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) - -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), c_1)[i!`%`_uN.0])))) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)], [CONST_instr(I32_numtype, c_2)]) + -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- if ($proj_num__0(c_2) =/= ?()) + -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0]) =/= ?()) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)|) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M)), ?(sx), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M)), ?(sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) - -- wf_shape: `%`(`%X%`_shape((pt : packtype <: lanetype), `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[i!`%`_uN.0] = $lpacknum_(Lnn, c_2)])) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(Lnn, c_2)])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)} + -- wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn, `%`_dim(M))), $lpacknum_(Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(Lnn), c_2)) -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(Lnn, `%`_dim(M)), i)) @@ -10206,76 +17228,102 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape(Lnn, `%`_dim(M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: + rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextunop__: `%%%%%`(sh_1, sh_2, vextunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: + rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextbinop__: `%%%%%%`(sh_1, sh_2, vextbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: + rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VEXTTERNOP_instr(sh_2, sh_1, vextternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextternop__: `%%%%%%%`(sh_1, sh_2, vextternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_}: + rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, sx : sx, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, sx)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vnarrowop__(sh_1!`%`_ishape.0, sh_2!`%`_ishape.0, sx, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, sx)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vnarrowop__: `%%%%%%`($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: + rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vcvtop__: `%%%%%`(sh_1, sh_2, vcvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -def $blocktype_(state : state, blocktype : blocktype) : instrtype +relation fun_blocktype_: `%%%`(state, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`})) - -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + rule fun_blocktype__case_0{z : state, x : uN, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%`(z, _IDX_blocktype(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#2*{t_1#2 <- `t_1*`}), `%`_resulttype(t_2#2*{t_2#2 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule fun_blocktype__case_1{z : state, `t?` : valtype?}: + `%%%`(z, _RESULT_blocktype(t#1?{t#1 <- `t?`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(state : state, blocktype : blocktype, ret_val : instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, `t?` : valtype?}(z, _RESULT_blocktype(t?{t <- `t?`})) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`}))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t?{t <- `t?`})))) + rule blocktype__is_wf_0{state : state, blocktype : blocktype, ret_val : instrtype, var_0 : instrtype}: + `%%%`(state, blocktype, ret_val) + -- wf_state: `%`(state) + -- wf_blocktype: `%`(blocktype) + -- if (ret_val = var_0) + -- wf_instrtype: `%`(ret_val) + -- fun_blocktype_: `%%%`(state, blocktype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_br_on_cast_fail-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_throw_ref-handler-next`: `%`(config) @@ -10295,9 +17343,12 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) + -- if (a < |$exninst(z)|) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10305,9 +17356,12 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_0`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) + -- if (a < |$exninst(z)|) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) @@ -10315,254 +17369,203 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) relation `Step_read_before_table.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_table.fill-succ`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.fill-zero_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.fill-oob_1`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_table.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_table.init-succ`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.init-zero_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `table.init-oob_1`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.fill-zero`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.fill-succ`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-zero_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.fill-oob_1`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.copy-zero`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.copy-le`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-zero_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(TRAP_instr) - -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.copy-gt`: `%`(config) - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-le_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- ~ `Step_read_before_memory.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - - ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-zero_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_memory.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.copy-oob_2`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + rule `memory.fill-oob_0`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.init-zero`: `%`(config) +relation `Step_read_before_memory.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + rule `memory.copy-oob_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation `Step_read_before_memory.init-succ`: `%`(config) +relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-zero_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + rule `memory.copy-zero_0`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `memory.copy-oob_1`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_instr: `%`(TRAP_instr) +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_memory.init-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `memory.init-oob_1`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + rule `memory.init-oob_0`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: + `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.test-false`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_ref.cast-fail`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_array.fill-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation `Step_read_before_array.fill-succ`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero_0`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob_1`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -10570,14 +17573,20 @@ relation `Step_read_before_array.copy-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if ($proj_num__0(i_2) =/= ?()) + -- if (a_2 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_0`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if ($proj_num__0(i_1) =/= ?()) + -- if (a_1 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10593,14 +17602,20 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if ($proj_num__0(i_2) =/= ?()) + -- if (a_2 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if ($proj_num__0(i_1) =/= ?()) + -- if (a_1 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10611,7 +17626,10 @@ relation `Step_read_before_array.copy-gt`: `%`(config) `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- if ($sx(zt_2) =/= ?()) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -10619,8 +17637,8 @@ relation `Step_read_before_array.copy-gt`: `%`(config) -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) @@ -10635,14 +17653,20 @@ relation `Step_read_before_array.copy-gt`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if ($proj_num__0(i_2) =/= ?()) + -- if (a_2 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1_2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if ($proj_num__0(i_1) =/= ?()) + -- if (a_1 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -10651,14 +17675,19 @@ relation `Step_read_before_array.init_elem-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10674,14 +17703,19 @@ relation `Step_read_before_array.init_elem-succ`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10691,7 +17725,10 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if ($proj_num__0(j) =/= ?()) + -- if ($zsize(zt) =/= ?()) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10699,7 +17736,10 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -10716,7 +17756,10 @@ relation `Step_read_before_array.init_data-num`: `%`(config) rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if ($proj_num__0(j) =/= ?()) + -- if ($zsize(zt) =/= ?()) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -10724,61 +17767,81 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) + rule block{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [BLOCK_instr(bt, instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) + rule loop{z : state, m : m, `val*` : val*, bt : blocktype, `instr*` : instr*, `t_1*` : valtype*, n : n, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})]), [`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [LOOP_instr(bt, instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`LABEL_%{%}%`_instr(m, [LOOP_instr(bt, instr*{instr <- `instr*`})], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_on_cast_fail-fail`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) - -- ~ `Step_read_before_br_on_cast_fail-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) + -- ~ `Step_read_before_br_on_cast_fail-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) + -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) + -- wf_instr: `%`(CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-null`{z : state, yy : typeuse}: @@ -10788,51 +17851,65 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `call_ref-func`{z : state, n : n, `val*` : val*, a : addr, yy : typeuse, m : m, f : frame, `instr*` : instr*, fi : funcinst, `t_1*` : valtype*, `t_2*` : valtype*, x : idx, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])]) -- if ($funcinst(z)[a] = fi) + -- if (a < |$funcinst(z)|) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) + -- (if ($default_(t) =/= ?()))*{t <- `t*`} + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(m, f, [`LABEL_%{%}%`_instr(m, [], instr*{instr <- `instr*`})])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- `t*`}, instr*{instr <- `instr*`})) -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))]) - -- if ($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0] = a) + `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) + -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($moduleinst(z)) -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) - -- wf_instr: `%`(RETURN_CALL_REF_instr(($funcinst(z)[a].TYPE_funcinst : deftype <: typeuse))) + -- wf_instr: `%`(RETURN_CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-label`{z : state, k : n, `instr'*` : instr*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'*{instr' <- `instr'*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-handler`{z : state, k : n, `catch*` : catch*, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, (val : val <: instr)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch*{catch <- `catch*`}, $instr_val(val)*{val <- `val*`} ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-null`{z : state, k : n, f : frame, `val*` : val*, yy : typeuse, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val : val <: instr)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val)*{val <- `val*`} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `return_call_ref-frame-addr`{z : state, k : n, f : frame, `val'*` : val*, n : n, `val*` : val*, a : addr, yy : typeuse, `instr*` : instr*, `t_1*` : valtype*, m : m, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) + `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})]), $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) -- Expand: `%~~%`($funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, (val' : val <: instr)*{val' <- `val'*`} ++ (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) + -- if (a < |$funcinst(z)|) + -- (wf_funcinst: `%`(iter))*{iter <- $funcinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- `val'*`} ++ $instr_val(val)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr*{instr <- `instr*`})])) -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1^n{t_1 <- `t_1*`}), `%`_resulttype(t_2^m{t_2 <- `t_2*`}))) + -- if (n = |`val*`|) + -- if (n = |`t_1*`|) + -- if (m = |`t_2*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-null`{z : state}: @@ -10842,9 +17919,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-instrs`{z : state, `val*` : val*, a : addr, `instr*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) + `%~>%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`})) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(THROW_REF_instr) @@ -10871,19 +17948,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)]) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) + -- if (a < |$exninst(z)|) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `throw_ref-handler-catch_ref`{z : state, n : n, x : idx, l : labelidx, `catch'*` : catch*, a : addr, `val*` : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[x!`%`_uN.0]) + `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) + -- if ($exninst(z)[a].TAG_exninst = $tagaddr(z)[$proj_uN_0(x).0]) + -- if (a < |$exninst(z)|) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- if (val*{val <- `val*`} = $exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [CATCH_REF_catch(x, l)] ++ catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) -- wf_instr: `%`(BR_instr(l)) @@ -10909,357 +17992,463 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch'*{catch' <- `catch'*`}, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], (val : val <: instr)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) + rule try_table{z : state, m : m, `val*` : val*, bt : blocktype, `catch*` : catch*, `instr*` : instr*, n : n, `t_1*` : valtype*, `t_2*` : valtype*, var_0 : instrtype}: + `%~>%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})]), [`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])]) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^m{val <- `val*`} ++ [TRY_TABLE_instr(bt, `%`_list(catch*{catch <- `catch*`}), instr*{instr <- `instr*`})])) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(n, catch*{catch <- `catch*`}, [`LABEL_%{%}%`_instr(n, [], $instr_val(val)^m{val <- `val*`} ++ instr*{instr <- `instr*`})])) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `t_2*`}))) + -- if (m = |`val*`|) + -- if (m = |`t_1*`|) + -- if (n = |`t_2*`|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [(val : val <: instr)]) + `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($local(z, x) = ?(val)) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- $local(z, x)} -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `global.get`{z : state, x : idx, val : val}: - `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [(val : val <: instr)]) + `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(val)]) -- if ($global(z, x).VALUE_globalinst = val) -- wf_val: `%`(val) + -- wf_globalinst: `%`($global(z, x)) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-oob`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.get-val`{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [($table(z, x).REFS_tableinst[!($proj_num__0(i))!`%`_uN.0] : ref <: instr)]) - -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [$instr_ref($table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: - `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) + `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($table(z, x)) -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) - -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), []) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- ~ `Step_read_before_table.fill-succ`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) + -- if (n =/= 0) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.FILL`_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$table(z, x_1).REFS_tableinst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$table(z, x_2).REFS_tableinst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_tableinst: `%`($table(z, x_1)) + -- wf_tableinst: `%`($table(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), []) - -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), []) + -- ~ `Step_read_before_table.copy-zero`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + -- ~ `Step_read_before_table.copy-le`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) - -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + -- ~ `Step_read_before_table.copy-gt`: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `TABLE.COPY`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_2) =/= ?()) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$table(z, x).REFS_tableinst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) - -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) ($elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0] : ref <: instr) `TABLE.SET`_instr(x) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- ~ `Step_read_before_table.init-succ`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) + -- if (n =/= 0) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$elem(z, y).REFS_eleminst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-num-val`{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) + -- if ($nbytes_(nt, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `load-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, n : n, sx : sx, x : idx, ao : memarg, c : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))]) - -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr((Inn : addrtype <: numtype), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) - -- wf_instr: `%`(CONST_instr((Inn : addrtype <: numtype), mk_num__0_num_(Inn, $extend__(n, $size((Inn : addrtype <: numtype)), sx, c)))) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)]), [CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))]) + -- if ($ibytes_(n, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(Inn), ?(mk_loadop__0_loadop_(Inn, `%_%`_loadop_Inn(`%`_sz(n), sx))), x, ao)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(Inn), mk_num__0_num_(Inn, $extend__(n, $size($numtype_addrtype(Inn)), sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-oob`{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-val`{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) + -- if ($vbytes_(V128_vectype, c) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-oob`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((M * K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-pack-val`{z : state, at : addrtype, i : num_, M : M, K : K, sx : sx, x : idx, ao : memarg, c : vec_, `j*` : iN*, Jnn : Jnn}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) + -- (if ($ibytes_(M, j) = $mem(z, x).BYTES_meminst[(($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((k * M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-splat-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) + -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))^M{})) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN(j!`%`_uN.0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-oob`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload-zero-val`{z : state, at : addrtype, i : num_, N : N, x : idx, ao : memarg, c : vec_, j : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) + -- if ($ibytes_(N, j) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (c = $extend__(N, 128, U_sx, j)) -- wf_uN: `%%`(N, j) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, j)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $extend__(N, 128, U_sx, j)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-oob`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `vload_lane-val`{z : state, at : addrtype, i : num_, c_1 : vec_, N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[(!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) + -- if ($ibytes_(N, k) = $mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)[[j!`%`_uN.0] = mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, k)} + -- wf_meminst: `%`($mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN(k!`%`_uN.0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.size`{z : state, x : idx, at : addrtype, n : n, lim : limits}: - `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))]) + `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) + -- wf_meminst: `%`($mem(z, x)) -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n)))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-oob`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-zero`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) - -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), []) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- ~ `Step_read_before_memory.fill-succ`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (val : val <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) + -- if (n =/= 0) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.FILL`_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-oob`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if (((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- wf_meminst: `%`($mem(z, x_1)) + -- wf_meminst: `%`($mem(z, x_2)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-zero`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) - -- ~ `Step_read_before_memory.copy-zero`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-le`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- ~ `Step_read_before_memory.copy-le`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- if (!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) + -- if (n =/= 0) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.copy-gt`{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- ~ `Step_read_before_memory.copy-gt`: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at_1 : addrtype <: numtype), i_1) CONST_instr((at_2 : addrtype <: numtype), i_2) CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), mk_num__0_num_(at_1, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), mk_num__0_num_(at_2, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- if (n =/= 0) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + n) <= |$mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + n) <= |$mem(z, x_2).BYTES_meminst|)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr((at_1 : addrtype <: numtype), i_1)) - -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) - -- wf_instr: `%`(CONST_instr((at' : addrtype <: numtype), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-oob`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) - -- if (((!($proj_num__0(i))!`%`_uN.0 + n) > |$mem(z, x).BYTES_meminst|) \/ ((!($proj_num__0(j))!`%`_uN.0 + n) > |$data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$data(z, y).BYTES_datainst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_datainst: `%`($data(z, y)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-zero`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) - -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0]!`%`_byte.0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- ~ `Step_read_before_memory.init-succ`: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), i)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0]!`%`_byte.0)))) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) + -- if (n =/= 0) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + n) <= |$mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + n) <= |$data(z, y).BYTES_datainst|)) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0)))) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$data(z, y).BYTES_datainst|) -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) @@ -11271,43 +18460,52 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.func`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0])]) + `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[x!`%`_uN.0])) + -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.test-false`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) - -- Ref_ok: `%|-%:%`(s, ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) + -- Ref_ok: `%|-%:%`(s, ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.cast-fail`{s : store, f : frame, ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [TRAP_instr]) - -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [TRAP_instr]) + -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), (val : val <: instr)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) + `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (if (!($default_($unpack(zt))) = ?(val)))*{val <- `val*`, zt <- `zt*`} + -- if (|`val*`| = |`zt*`|) + -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- `zt*`} -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- `zt*`} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- `zt*`} -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -11320,17 +18518,26 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [(!($unpackfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[i!`%`_uN.0])) : val <: instr)]) + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- wf_val: `%`(!($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) + -- if ($unpackfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) + -- if (a < |$structinst(z)|) + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), (val : val <: instr)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)]), $instr_val(val)^n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if (!($default_($unpack(zt))) = ?(val)) + -- if ($default_($unpack(zt)) =/= ?()) -- wf_val: `%`(val) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DEFAULT`_instr(x)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11338,23 +18545,31 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-alloc`{z : state, i : num_, n : n, x : idx, y : idx, `ref*` : ref*}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), (ref : ref <: instr)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) - -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[!($proj_num__0(i))!`%`_uN.0 : n]) + `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)]), $instr_ref(ref)^n{ref <- `ref*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) + -- if ($proj_num__0(i) =/= ?()) -- (wf_ref: `%`(ref))*{ref <- `ref*`} + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_ELEM`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- if (n = |`ref*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(i))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if ($proj_num__0(i) =/= ?()) + -- if ($zsize(zt) =/= ?()) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11363,11 +18578,20 @@ relation Step_read: `%~>%`(config, instr*) rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?}: `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^n{c <- `c*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[!($proj_num__0(i))!`%`_uN.0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($zsize(zt) =/= ?()) + -- if ($proj_num__0(i) =/= ?()) -- (wf_lit_: `%%`(zt, c))*{c <- `c*`} + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^n{c <- `c*`} + -- (if ($cunpack(zt) =/= ?()))^n{} + -- (wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)))^n{c <- `c*`} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^n{c <- `c*`} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.NEW_DATA`_instr(x, y)])) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (n = |`c*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -11378,14 +18602,23 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-oob`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[!($proj_num__0(i))!`%`_uN.0])) : val <: instr)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) + -- if ($unpackfield_(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (a < |$arrayinst(z)|) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11400,62 +18633,73 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))]) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$arrayinst(z)[a].FIELDS_arrayinst|)))) + -- if (a < |$arrayinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-null`{z : state, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-oob`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-zero`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) - -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), []) + -- ~ `Step_read_before_array.fill-zero`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- if (n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.fill-succ`{z : state, a : addr, i : num_, val : val, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) + -- ~ `Step_read_before_array.fill-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-null1`{z : state, i_1 : num_, ref : ref, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) (ref : ref <: instr) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-null2`{z : state, ref : ref, i_1 : num_, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob1`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + n) > |$arrayinst(z)[a_1].FIELDS_arrayinst|) + -- if ($proj_num__0(i_1) =/= ?()) + -- if (a_1 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-oob2`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- if ((!($proj_num__0(i_2))!`%`_uN.0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + n) > |$arrayinst(z)[a_2].FIELDS_arrayinst|) + -- if ($proj_num__0(i_2) =/= ?()) + -- if (a_2 < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) @@ -11468,10 +18712,13 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-le`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) -- ~ `Step_read_before_array.copy-le`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) - -- if ((!($proj_num__0(i_1))!`%`_uN.0 <= !($proj_num__0(i_2))!`%`_uN.0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !($sx(zt_2)))) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) + -- if ($sx(zt_2) =/= ?()) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -11479,23 +18726,26 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_1))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i_2))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.copy-gt`{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) -- ~ `Step_read_before_array.copy-gt`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- Expand: `%~~%`($type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_2))) -- if (sx?{sx <- `sx?`} = !($sx(zt_2))) + -- if ($sx(zt_2) =/= ?()) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.COPY`_instr(x_1, x_2)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_1))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_1) =/= ?()) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(((((!($proj_num__0(i_2))!`%`_uN.0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- if ($proj_num__0(i_2) =/= ?()) -- wf_instr: `%`(`ARRAY.GET`_instr(sx?{sx <- `sx?`}, x_2)) -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) @@ -11513,14 +18763,19 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(j))!`%`_uN.0 + n) > |$elem(z, y).REFS_eleminst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11533,16 +18788,20 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_elem-succ`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, ref : ref}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (ref : ref <: instr) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_ref(ref) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) -- ~ `Step_read_before_array.init_elem-succ`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if (ref = $elem(z, y).REFS_eleminst[!($proj_num__0(j))!`%`_uN.0]) + -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) -- wf_ref: `%`(ref) + -- wf_eleminst: `%`($elem(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_ELEM`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) @@ -11555,7 +18814,10 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-oob1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- if ((!($proj_num__0(i))!`%`_uN.0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) @@ -11563,7 +18825,10 @@ relation Step_read: `%~>%`(config, instr*) rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ((!($proj_num__0(j))!`%`_uN.0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- if ($proj_num__0(j) =/= ?()) + -- if ($zsize(zt) =/= ?()) + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11577,17 +18842,25 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.init_data-num`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, zt : storagetype, c : lit_, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) -- ~ `Step_read_before_array.init_data-num`: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[!($proj_num__0(j))!`%`_uN.0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(j) =/= ?()) + -- if ($zsize(zt) =/= ?()) -- wf_lit_: `%%`(zt, c) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- if ($cunpack(zt) =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($data(z, y)) -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.INIT_DATA`_instr(x, y)])) -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(i))!`%`_uN.0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((!($proj_num__0(j))!`%`_uN.0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -11613,11 +18886,11 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:32.1-35.41 rule `ctxt-instrs`{z : state, `val*` : val*, `instr*` : instr*, `instr_1*` : instr*, z' : state, `instr'*` : instr*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) + `%~>%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`}), `%;%`_config(z', $instr_val(val)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) -- if ((val*{val <- `val*`} =/= []) \/ (instr_1*{instr_1 <- `instr_1*`} =/= [])) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)*{val <- `val*`} ++ instr*{instr <- `instr*`} ++ instr_1*{instr_1 <- `instr_1*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`} ++ instr'*{instr' <- `instr'*`} ++ instr_1*{instr_1 <- `instr_1*`})) -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) -- wf_config: `%`(`%;%`_config(z', instr'*{instr' <- `instr'*`})) @@ -11650,53 +18923,68 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) -- if (a = |$exninst(z)|) - -- if (exn = {TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [THROW_instr(x)])) + -- if (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) + -- wf_taginst: `%`($tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $exninst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) - -- wf_exninst: `%`({TAG $tagaddr(z)[x!`%`_uN.0], FIELDS val^n{val <- `val*`}}) + -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (n = |`val*`|) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule `local.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `LOCAL.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_local(z, x, val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:318.1-319.58 rule `global.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) - -- wf_config: `%`(`%;%`_config(z, [(val : val <: instr) `GLOBAL.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config($with_global(z, x, val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule `table.set-oob`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) - -- if (!($proj_num__0(i))!`%`_uN.0 < |$table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_table(z, x, !($proj_num__0(i))!`%`_uN.0, ref), [])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 - rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) - -- if (ti = !($growtable($table(z, x), n, ref))) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_0 : tableinst?}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- if (ti = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(!(var_0)) + -- wf_tableinst: `%`($table(z, x)) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:352.1-353.87 - rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [(ref : ref <: instr) CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) + rule `table.grow-fail`{z : state, ref : ref, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- wf_config: `%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:413.1-414.51 rule `elem.drop`{z : state, x : idx}: @@ -11706,75 +18994,100 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule `store-num-oob`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule `store-pack-oob`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr((Inn : addrtype <: numtype), c) STORE_instr((Inn : addrtype <: numtype), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- if ($proj_num__0(c) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))} + -- wf_uN: `%%`(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c)))) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(Inn), c) STORE_instr($numtype_addrtype(Inn), ?(mk_storeop__0_storeop_(Inn, `%`_storeop_Inn(`%`_sz(n)))), x, ao)])) + -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule `vstore-oob`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule `vstore_lane-oob`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if (((!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0) + N) > |$mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + N) > |$mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule `vstore_lane-val`{z : state, at : addrtype, i : num_, c : vec_, N : N, x : idx, ao : memarg, j : laneidx, `b*` : byte*, Jnn : Jnn, M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) - -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, (!($proj_num__0(i))!`%`_uN.0 + ao.OFFSET_memarg!`%`_uN.0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) - -- wf_uN: `%%`(N, `%`_uN(!($proj_lane__2($lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c)[j!`%`_uN.0]))!`%`_uN.0)) + -- if (b*{b <- `b*`} = $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]) =/= ?()) + -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)|) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))} + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)])) + -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b*{b <- `b*`}), [])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 - rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if (mi = !($growmem($mem(z, x), n))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_0 : meminst?}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- if (mi = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(!(var_0)) + -- wf_meminst: `%`($mem(z, x)) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- fun_growmem: `%%%`($mem(z, x), n, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:554.1-555.84 - rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), mk_num__0_num_(at, `%`_uN($inv_signed_($size((at : addrtype <: numtype)), - (1 : nat <:> int)))))])) + rule `memory.grow-fail`{z : state, at : addrtype, n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:615.1-616.51 rule `data.drop`{z : state, x : idx}: @@ -11784,58 +19097,73 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:692.1-696.65 rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) -- if (si = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) + -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} + -- (wf_structinst: `%`(iter))*{iter <- $structinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- if (n = |`val*`|) + -- if (n = |`mut?*`|) + -- if (n = |`zt*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr (val : val <: instr) `STRUCT.SET`_instr(x, i)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(val) `STRUCT.SET`_instr(x, i)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, i!`%`_uN.0, !($packfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], val))), [])) + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) (val : val <: instr) `STRUCT.SET`_instr(x, i)])) - -- wf_config: `%`(`%;%`_config($with_struct(z, a, i!`%`_uN.0, !($packfield_(zt*{zt <- `zt*`}[i!`%`_uN.0], val))), [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) + -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val))), [])) + -- if ($packfield_(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val) =/= ?()) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:732.1-737.65 rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}})) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) + -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- if (n = |`val*`|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule `array.set-oob`{z : state, a : addr, i : num_, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if (!($proj_num__0(i))!`%`_uN.0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $arrayinst(z)} + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, !($proj_num__0(i))!`%`_uN.0, !($packfield_(zt, val))), [])) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_array(z, a, !($proj_num__0(i))!`%`_uN.0, !($packfield_(zt, val))), [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, val))), [])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($packfield_(zt, val) =/= ?()) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) } @@ -11864,355 +19192,777 @@ relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule _{z : state, `instr*` : instr*, z' : state, `val*` : val*}: `%;%~>*%;%`(z, instr*{instr <- `instr*`}, z', val*{val <- `val*`}) - -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`})) + -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', $instr_val(val)*{val <- `val*`})) -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`})) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.1-7.63 -def $alloctypes(type*) : deftype* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:8.1-8.27 - def $alloctypes([]) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:9.1-13.24 - def $alloctypes{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN}(type'*{type' <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} - -- let{`deftype'*` : deftype*} deftype'*{deftype' <- `deftype'*`} = $alloctypes(type'*{type' <- `type'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 +relation fun_alloctypes: `%%`(type*, deftype*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype*` : deftype*, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- let{`deftype'*` : deftype*} deftype'#1*{deftype'#1 <- `deftype'*`} = var_0 -- let{rectype : rectype} TYPE_type(rectype) = type - -- if (deftype*{deftype <- `deftype*`} = $subst_all_deftypes($rolldt(x, rectype), (deftype' : deftype <: typeuse)*{deftype' <- `deftype'*`})) - -- if (x!`%`_uN.0 = |deftype'*{deftype' <- `deftype'*`}|) + -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) + -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) -- wf_uN: `%%`(32, x) + -- fun_rolldt: `%%%`(x, rectype, var_2) + -- fun_subst_all_deftypes: `%%%`(var_2, $typeuse_deftype(deftype'#2)*{deftype'#2 <- `deftype'*`}, var_1) + -- fun_alloctypes: `%%`(type'#2*{type'#2 <- `type'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) +relation fun_alloctag: `%%%`(store, tagtype, (store, tagaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctag{s : store, tagtype : typeuse, taginst : taginst}(s, tagtype) = (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) + rule fun_alloctag_case_0{s : store, tagtype : typeuse, taginst : taginst}: + `%%%`(s, tagtype, (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|)) -- if (taginst = {TYPE tagtype}) - -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(store : store, tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{store : store, tagtype : tagtype, ret_val : (store, tagaddr), var_0 : (store, tagaddr)}: + `%%%`(store, tagtype, ret_val) + -- wf_store: `%`(store) + -- wf_typeuse: `%`(tagtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctag: `%%%`(store, tagtype, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- let{ja : tagaddr, s_1 : store} (s_1, ja) = var_0 + -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'#1*{ja'#1 <- `ja'*`}) = var_1 + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.1-20.102 -def $alloctags(store : store, tagtype*) : (store, tagaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:21.1-21.34 - def $alloctags{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:22.1-24.49 - def $alloctags{s : store, tagtype : typeuse, `tagtype'*` : tagtype*}(s, [tagtype] ++ tagtype'*{tagtype' <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) - -- let{ja : tagaddr, s_1 : store} (s_1, ja) = $alloctag(s, tagtype) - -- let{s_2 : store, `ja'*` : tagaddr*} (s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{store : store, var_0 : tagtype*, ret_val : (store, tagaddr*), var_1 : (store, tagaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_alloctags: `%%%`(store, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, globaladdr) +relation fun_allocglobal: `%%%%`(store, globaltype, val, (store, globaladdr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocglobal{s : store, globaltype : globaltype, val : val, globalinst : globalinst}(s, globaltype, val) = (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) + rule fun_allocglobal_case_0{s : store, globaltype : globaltype, val : val, globalinst : globalinst}: + `%%%%`(s, globaltype, val, (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|)) -- if (globalinst = {TYPE globaltype, VALUE val}) - -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{store : store, globaltype : globaltype, val : val, ret_val : (store, globaladdr), var_0 : (store, globaladdr)}: + `%%%%`(store, globaltype, val, ret_val) + -- wf_store: `%`(store) + -- wf_globaltype: `%`(globaltype) + -- wf_val: `%`(val) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobal: `%%%%`(store, globaltype, val, var_0) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.1-31.122 -def $allocglobals(store : store, globaltype*, val*) : (store, globaladdr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:32.1-32.42 - def $allocglobals{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:33.1-35.62 - def $allocglobals{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*}(s, [globaltype] ++ globaltype'*{globaltype' <- `globaltype'*`}, [val] ++ val'*{val' <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) - -- let{ga : globaladdr, s_1 : store} (s_1, ga) = $allocglobal(s, globaltype, val) - -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation fun_allocglobals: `%%%%`(store, globaltype*, val*, (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: + `%%%%`(s, [globaltype] ++ globaltype'#1*{globaltype'#1 <- `globaltype'*`}, [val] ++ val'#1*{val'#1 <- `val'*`}, (s_2, [ga] ++ ga'*{ga' <- `ga'*`})) + -- let{ga : globaladdr, s_1 : store} (s_1, ga) = var_0 + -- let{s_2 : store, `ga'*` : globaladdr*} (s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1 + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(store : store, memtype : memtype) : (store, memaddr) +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*), var_2 : (store, globaladdr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobals: `%%%%`(store, var_0, var_1, var_2) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocmem: `%%%`(store, memtype, (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocmem_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}: + `%%%`(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#11?{j#11 <- `j?`})), (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|)) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(store : store, memtype : memtype, ret_val : (store, memaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmem{s : store, at : addrtype, i : uN, `j?` : u64?, meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`}))) = (s +++ {TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) - -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^(i!`%`_uN.0 * (64 * $Ki)){}}) + rule allocmem_is_wf_0{store : store, memtype : memtype, ret_val : (store, memaddr), var_0 : (store, memaddr)}: + `%%%`(store, memtype, ret_val) + -- wf_store: `%`(store) + -- wf_memtype: `%`(memtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocmem: `%%%`(store, memtype, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- let{ma : memaddr, s_1 : store} (s_1, ma) = var_0 + -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'#1*{ma'#1 <- `ma'*`}) = var_1 + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) +} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.1-42.102 -def $allocmems(store : store, memtype*) : (store, memaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:43.1-43.34 - def $allocmems{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:44.1-46.49 - def $allocmems{s : store, memtype : memtype, `memtype'*` : memtype*}(s, [memtype] ++ memtype'*{memtype' <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) - -- let{ma : memaddr, s_1 : store} (s_1, ma) = $allocmem(s, memtype) - -- let{s_2 : store, `ma'*` : memaddr*} (s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{store : store, var_0 : memtype*, ret_val : (store, memaddr*), var_1 : (store, memaddr*)}: + `%%%`(store, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocmems: `%%%`(store, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, tableaddr) +relation fun_alloctable: `%%%%`(store, tabletype, ref, (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_alloctable_case_0{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}: + `%%%%`(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j#14?{j#14 <- `j?`}), rt), ref, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|)) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctable{s : store, at : addrtype, i : uN, `j?` : u64?, rt : reftype, ref : ref, tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) - -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^i!`%`_uN.0{}}) + rule alloctable_is_wf_0{store : store, tabletype : tabletype, ref : ref, ret_val : (store, tableaddr), var_0 : (store, tableaddr)}: + `%%%%`(store, tabletype, ref, ret_val) + -- wf_store: `%`(store) + -- wf_tabletype: `%`(tabletype) + -- wf_ref: `%`(ref) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctable: `%%%%`(store, tabletype, ref, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.1-53.118 -def $alloctables(store : store, tabletype*, ref*) : (store, tableaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:54.1-54.41 - def $alloctables{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:55.1-57.60 - def $alloctables{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*}(s, [tabletype] ++ tabletype'*{tabletype' <- `tabletype'*`}, [ref] ++ ref'*{ref' <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) - -- let{ta : tableaddr, s_1 : store} (s_1, ta) = $alloctable(s, tabletype, ref) - -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation fun_alloctables: `%%%%`(store, tabletype*, ref*, (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: + `%%%%`(s, [tabletype] ++ tabletype'#1*{tabletype'#1 <- `tabletype'*`}, [ref] ++ ref'#1*{ref'#1 <- `ref'*`}, (s_2, [ta] ++ ta'*{ta' <- `ta'*`})) + -- let{ta : tableaddr, s_1 : store} (s_1, ta) = var_0 + -- let{s_2 : store, `ta'*` : tableaddr*} (s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1 + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst) : (store, funcaddr) +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*), var_2 : (store, tableaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_alloctables: `%%%%`(store, var_0, var_1, var_2) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, (store, funcaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocfunc{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}(s, deftype, funccode, moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) + rule fun_allocfunc_case_0{s : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, funcinst : funcinst}: + `%%%%%`(s, deftype, funccode, moduleinst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|)) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{store : store, deftype : deftype, funccode : funccode, moduleinst : moduleinst, ret_val : (store, funcaddr), var_0 : (store, funcaddr)}: + `%%%%%`(store, deftype, funccode, moduleinst, ret_val) + -- wf_store: `%`(store) + -- wf_funccode: `%`(funccode) + -- wf_moduleinst: `%`(moduleinst) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_0{s : store}: + `%%%%%`(s, [], [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_1{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*, var_1 : (store, funcaddr*), var_0 : (store, funcaddr)}: + `%%%%%`(s, [dt] ++ dt'#3*{dt'#3 <- `dt'*`}, [funccode] ++ funccode'#1*{funccode'#1 <- `funccode'*`}, [moduleinst] ++ moduleinst'#1*{moduleinst'#1 <- `moduleinst'*`}, (s_2, [fa] ++ fa'*{fa' <- `fa'*`})) + -- let{fa : funcaddr, s_1 : store} (s_1, fa) = var_0 + -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1 + -- fun_allocfuncs: `%%%%%`(s_1, dt'#4*{dt'#4 <- `dt'*`}, funccode'#2*{funccode'#2 <- `funccode'*`}, moduleinst'#2*{moduleinst'#2 <- `moduleinst'*`}, var_1) + -- fun_allocfunc: `%%%%%`(s, dt, funccode, moduleinst, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.1-64.133 -def $allocfuncs(store : store, deftype*, funccode*, moduleinst*) : (store, funcaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:65.1-65.45 - def $allocfuncs{s : store}(s, [], [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:66.1-68.71 - def $allocfuncs{s : store, dt : deftype, `dt'*` : deftype*, funccode : funccode, `funccode'*` : funccode*, moduleinst : moduleinst, `moduleinst'*` : moduleinst*}(s, [dt] ++ dt'*{dt' <- `dt'*`}, [funccode] ++ funccode'*{funccode' <- `funccode'*`}, [moduleinst] ++ moduleinst'*{moduleinst' <- `moduleinst'*`}) = (s_2, [fa] ++ fa'*{fa' <- `fa'*`}) - -- let{fa : funcaddr, s_1 : store} (s_1, fa) = $allocfunc(s, dt, funccode, moduleinst) - -- let{s_2 : store, `fa'*` : funcaddr*} (s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*), var_3 : (store, funcaddr*)}: + `%%%%%`(store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = var_3) + -- wf_store: `%`(ret_val.0) + -- fun_allocfuncs: `%%%%%`(store, var_0, var_1, var_2, var_3) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) +relation fun_allocdata: `%%%%`(store, datatype, byte*, (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocdata_case_0{s : store, `byte*` : byte*, datainst : datainst}: + `%%%%`(s, OK_datatype, byte#2*{byte#2 <- `byte*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|)) + -- if (datainst = {BYTES byte#3*{byte#3 <- `byte*`}}) + -- wf_datainst: `%`({BYTES byte#4*{byte#4 <- `byte*`}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocdata{s : store, `byte*` : byte*, datainst : datainst}(s, OK_datatype, byte*{byte <- `byte*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) - -- if (datainst = {BYTES byte*{byte <- `byte*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) + rule allocdata_is_wf_0{store : store, datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr), var_1 : (store, dataaddr)}: + `%%%%`(store, datatype, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocdata: `%%%%`(store, datatype, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation fun_allocdatas: `%%%%`(store, datatype*, byte**, (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(s, [ok] ++ ok'#1*{ok'#1 <- `ok'*`}, [b#8*{b#8 <- `b*`}] ++ b'#1*{b'#1 <- `b'*#1`}*{`b'*#1` <- `b'**`}, (s_2, [da] ++ da'*{da' <- `da'*`})) + -- let{da : dataaddr, s_1 : store} (s_1, da) = var_0 + -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'#1*{da'#1 <- `da'*`}) = var_1 + -- fun_allocdatas: `%%%%`(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`}, var_1) + -- fun_allocdata: `%%%%`(s, ok, b#9*{b#9 <- `b*`}, var_0) +} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.1-75.118 -def $allocdatas(store : store, datatype*, byte**) : (store, dataaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 - def $allocdatas{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**}(s, [ok] ++ ok'*{ok' <- `ok'*`}, [b*{b <- `b*`}] ++ b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b*{b <- `b*`}) - -- let{s_2 : store, `da'*` : dataaddr*} (s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*), var_2 : (store, dataaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocdatas: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) +relation fun_allocelem: `%%%%`(store, elemtype, ref*, (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocelem_case_0{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}: + `%%%%`(s, elemtype, ref#1*{ref#1 <- `ref*`}, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|)) + -- if (eleminst = {TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) + -- wf_eleminst: `%`({TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocelem{s : store, elemtype : reftype, `ref*` : ref*, eleminst : eleminst}(s, elemtype, ref*{ref <- `ref*`}) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) - -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) + rule allocelem_is_wf_0{store : store, elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr), var_1 : (store, elemaddr)}: + `%%%%`(store, elemtype, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_reftype: `%`(elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocelem: `%%%%`(store, elemtype, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation fun_allocelems: `%%%%`(store, elemtype*, ref**, (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: + `%%%%`(s, [rt] ++ rt'#1*{rt'#1 <- `rt'*`}, [ref#4*{ref#4 <- `ref*`}] ++ ref'#3*{ref'#3 <- `ref'*#1`}*{`ref'*#1` <- `ref'**`}, (s_2, [ea] ++ ea'*{ea' <- `ea'*`})) + -- let{ea : elemaddr, s_1 : store} (s_1, ea) = var_0 + -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1 + -- fun_allocelems: `%%%%`(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`}, var_1) + -- fun_allocelem: `%%%%`(s, rt, ref#5*{ref#5 <- `ref*`}, var_0) +} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.1-86.117 -def $allocelems(store : store, elemtype*, ref**) : (store, elemaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:87.1-87.40 - def $allocelems{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:88.1-90.55 - def $allocelems{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**}(s, [rt] ++ rt'*{rt' <- `rt'*`}, [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = (s_2, [ea] ++ ea'*{ea' <- `ea'*`}) - -- let{ea : elemaddr, s_1 : store} (s_1, ea) = $allocelem(s, rt, ref*{ref <- `ref*`}) - -- let{s_2 : store, `ea'*` : elemaddr*} (s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*), var_2 : (store, elemaddr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocelems: `%%%%`(store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(moduleinst : moduleinst, export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[x!`%`_uN.0])}) + def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TAG_externidx(x))) = {NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, GLOBAL_externidx(x))) = {NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[x!`%`_uN.0])}) + def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, MEM_externidx(x))) = {NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[x!`%`_uN.0])}) + def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, TABLE_externidx(x))) = {NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[x!`%`_uN.0])}) + def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(moduleinst : moduleinst, export : export, ret_val : exportinst) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexport{moduleinst : moduleinst, name : name, x : uN}(moduleinst, EXPORT_export(name, FUNC_externidx(x))) = {NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])} - -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[x!`%`_uN.0])}) + rule allocexport_is_wf_0{moduleinst : moduleinst, export : export, ret_val : exportinst}: + `%%%`(moduleinst, export, ret_val) + -- wf_moduleinst: `%`(moduleinst) + -- wf_export: `%`(export) + -- if (ret_val = $allocexport(moduleinst, export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(moduleinst : moduleinst, export*) : exportinst* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export*{export <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} + def $allocexports{moduleinst : moduleinst, `export*` : export*}(moduleinst, export#3*{export#3 <- `export*`}) = $allocexport(moduleinst, export)*{export <- `export*`} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) : (store, moduleinst) +relation allocexports_is_wf: `%%%`(moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmodule{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*}(s, module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = (s_7, moduleinst) - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (tag*{tag <- `tag*`} = TAG_tag(tagtype)*{tagtype <- `tagtype*`}) - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (mem*{mem <- `mem*`} = MEMORY_mem(memtype)*{memtype <- `memtype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (func*{func <- `func*`} = FUNC_func(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`}) - -- let{`aa_I*` : tagaddr*} aa_I*{aa_I <- `aa_I*`} = $tagsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ga_I*` : globaladdr*} ga_I*{ga_I <- `ga_I*`} = $globalsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ma_I*` : memaddr*} ma_I*{ma_I <- `ma_I*`} = $memsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`ta_I*` : tableaddr*} ta_I*{ta_I <- `ta_I*`} = $tablesxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`fa_I*` : funcaddr*} fa_I*{fa_I <- `fa_I*`} = $funcsxa(externaddr*{externaddr <- `externaddr*`}) - -- let{`dt*` : deftype*} dt*{dt <- `dt*`} = $alloctypes(type*{type <- `type*`}) - -- let{`fa*` : nat*} fa*{fa <- `fa*`} = (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){} - -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa*{aa <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tagtype <- `tagtype*`}) - -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga*{ga <- `ga*`}) = $allocglobals(s_1, $subst_all_globaltype(globaltype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{globaltype <- `globaltype*`}, val_G*{val_G <- `val_G*`}) - -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma*{ma <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{memtype <- `memtype*`}) - -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta*{ta <- `ta*`}) = $alloctables(s_3, $subst_all_tabletype(tabletype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tabletype <- `tabletype*`}, ref_T*{ref_T <- `ref_T*`}) - -- let{s_5 : store, `da*` : dataaddr*} (s_5, da*{da <- `da*`}) = $allocdatas(s_4, OK_datatype^|data*{data <- `data*`}|{}, byte*{byte <- `byte*`}*{`byte*` <- `byte**`}) - -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea*{ea <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{elemtype <- `elemtype*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- if ((s_7, fa*{fa <- `fa*`}) = $allocfuncs(s_6, dt*{dt <- `dt*`}[x!`%`_uN.0]*{x <- `x*`}, FUNC_funccode(x, local*{local <- `local*`}, expr_F)*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`}, moduleinst^|func*{func <- `func*`}|{})) - -- if (xi*{xi <- `xi*`} = $allocexports({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export*{export <- `export*`})) - -- if (moduleinst = {TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) - -- wf_store: `%`(s_7) + rule allocexports_is_wf_0{moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(moduleinst, var_0, ret_val) -- wf_moduleinst: `%`(moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_tag: `%`(TAG_tag(tagtype)))*{tagtype <- `tagtype*`} - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_mem: `%`(MEMORY_mem(memtype)))*{memtype <- `memtype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_func: `%`(FUNC_func(x, local*{local <- `local*`}, expr_F)))*{expr_F <- `expr_F*`, `local*` <- `local**`, x <- `x*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(elemtype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, elemtype <- `elemtype*`, `expr_E*` <- `expr_E**`} - -- wf_moduleinst: `%`({TYPES [], TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) - -- wf_moduleinst: `%`({TYPES dt*{dt <- `dt*`}, TAGS aa_I*{aa_I <- `aa_I*`} ++ aa*{aa <- `aa*`}, GLOBALS ga_I*{ga_I <- `ga_I*`} ++ ga*{ga <- `ga*`}, MEMS ma_I*{ma_I <- `ma_I*`} ++ ma*{ma <- `ma*`}, TABLES ta_I*{ta_I <- `ta_I*`} ++ ta*{ta <- `ta*`}, FUNCS fa_I*{fa_I <- `fa_I*`} ++ fa*{fa <- `fa*`}, DATAS da*{da <- `da*`}, ELEMS ea*{ea <- `ea*`}, EXPORTS xi*{xi <- `xi*`}}) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $rundata_(dataidx : dataidx, data : data) : instr* +relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref**, (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*}(x, DATA_data(b^n{b <- `b*`}, PASSIVE_datamode)) = [] + rule fun_allocmodule_case_0{s : store, module : module, `externaddr*` : externaddr*, `val_G*` : val*, `ref_T*` : ref*, `ref_E**` : ref**, s_7 : store, moduleinst : moduleinst, `tagtype*` : tagtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `memtype*` : memtype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `expr_F*` : expr*, `local**` : local**, `x*` : idx*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `elemtype*` : elemtype*, `expr_E**` : expr**, `xi*` : exportinst*, var_17 : (store, funcaddr*), `var_16*` : elemtype*, var_15 : (store, elemaddr*), var_14 : (store, dataaddr*), `var_13*` : tabletype*, var_12 : (store, tableaddr*), `var_11*` : memtype*, var_10 : (store, memaddr*), `var_9*` : globaltype*, var_8 : (store, globaladdr*), `var_7*` : tagtype*, var_6 : (store, tagaddr*), var_5 : deftype*, var_4 : funcaddr*, var_3 : tableaddr*, var_2 : memaddr*, var_1 : globaladdr*, var_0 : tagaddr*}: + `%%%%%%%`(s, module, externaddr#1*{externaddr#1 <- `externaddr*`}, val_G#1*{val_G#1 <- `val_G*`}, ref_T#1*{ref_T#1 <- `ref_T*`}, ref_E#1*{ref_E#1 <- `ref_E*#1`}*{`ref_E*#1` <- `ref_E**`}, (s_7, moduleinst)) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#2*{type#2 <- `type*`}), `%`_list(import#2*{import#2 <- `import*`}), `%`_list(tag#2*{tag#2 <- `tag*`}), `%`_list(global#3*{global#3 <- `global*`}), `%`_list(mem#3*{mem#3 <- `mem*`}), `%`_list(table#3*{table#3 <- `table*`}), `%`_list(func#3*{func#3 <- `func*`}), `%`_list(data#2*{data#2 <- `data*`}), `%`_list(elem#3*{elem#3 <- `elem*`}), start#3?{start#3 <- `start?`}, `%`_list(export#4*{export#4 <- `export*`})) = module + -- if (tag#3*{tag#3 <- `tag*`} = TAG_tag(tagtype#78)*{tagtype#78 <- `tagtype*`}) + -- if (global#4*{global#4 <- `global*`} = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`}) + -- if (mem#4*{mem#4 <- `mem*`} = MEMORY_mem(memtype#122)*{memtype#122 <- `memtype*`}) + -- if (table#4*{table#4 <- `table*`} = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`}) + -- if (func#4*{func#4 <- `func*`} = FUNC_func(x#2, local#2*{local#2 <- `local*#82`}, expr_F#1)*{expr_F#1 <- `expr_F*`, `local*#82` <- `local**`, x#2 <- `x*`}) + -- if (data#3*{data#3 <- `data*`} = DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`}) + -- if (elem#4*{elem#4 <- `elem*`} = ELEM_elem(elemtype#1, expr_E#1*{expr_E#1 <- `expr_E*#1`}, elemmode#230)*{elemmode#230 <- `elemmode*`, elemtype#1 <- `elemtype*`, `expr_E*#1` <- `expr_E**`}) + -- let{`aa_I*` : tagaddr*} aa_I#1*{aa_I#1 <- `aa_I*`} = var_0 + -- let{`ga_I*` : globaladdr*} ga_I#1*{ga_I#1 <- `ga_I*`} = var_1 + -- let{`ma_I*` : memaddr*} ma_I#1*{ma_I#1 <- `ma_I*`} = var_2 + -- let{`ta_I*` : tableaddr*} ta_I#1*{ta_I#1 <- `ta_I*`} = var_3 + -- let{`fa_I*` : funcaddr*} fa_I#1*{fa_I#1 <- `fa_I*`} = var_4 + -- let{`dt*` : deftype*} dt#8*{dt#8 <- `dt*`} = var_5 + -- let{`fa*` : nat*} fa#1*{fa#1 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#5*{func#5 <- `func*`}|){} + -- let{s_1 : store, `aa*` : tagaddr*} (s_1, aa#1*{aa#1 <- `aa*`}) = var_6 + -- let{s_2 : store, `ga*` : globaladdr*} (s_2, ga#1*{ga#1 <- `ga*`}) = var_8 + -- let{s_3 : store, `ma*` : memaddr*} (s_3, ma#1*{ma#1 <- `ma*`}) = var_10 + -- let{s_4 : store, `ta*` : tableaddr*} (s_4, ta#1*{ta#1 <- `ta*`}) = var_12 + -- let{s_5 : store, `da*` : dataaddr*} (s_5, da#1*{da#1 <- `da*`}) = var_14 + -- let{s_6 : store, `ea*` : elemaddr*} (s_6, ea#1*{ea#1 <- `ea*`}) = var_15 + -- if ((s_7, fa#2*{fa#2 <- `fa*`}) = var_17) + -- if (xi#1*{xi#1 <- `xi*`} = $allocexports({TYPES [], TAGS aa_I#2*{aa_I#2 <- `aa_I*`} ++ aa#2*{aa#2 <- `aa*`}, GLOBALS ga_I#2*{ga_I#2 <- `ga_I*`} ++ ga#2*{ga#2 <- `ga*`}, MEMS ma_I#2*{ma_I#2 <- `ma_I*`} ++ ma#2*{ma#2 <- `ma*`}, TABLES ta_I#2*{ta_I#2 <- `ta_I*`} ++ ta#2*{ta#2 <- `ta*`}, FUNCS fa_I#2*{fa_I#2 <- `fa_I*`} ++ fa#3*{fa#3 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}, export#5*{export#5 <- `export*`})) + -- if (moduleinst = {TYPES dt#15*{dt#15 <- `dt*`}, TAGS aa_I#3*{aa_I#3 <- `aa_I*`} ++ aa#3*{aa#3 <- `aa*`}, GLOBALS ga_I#3*{ga_I#3 <- `ga_I*`} ++ ga#3*{ga#3 <- `ga*`}, MEMS ma_I#3*{ma_I#3 <- `ma_I*`} ++ ma#3*{ma#3 <- `ma*`}, TABLES ta_I#3*{ta_I#3 <- `ta_I*`} ++ ta#3*{ta#3 <- `ta*`}, FUNCS fa_I#3*{fa_I#3 <- `fa_I*`} ++ fa#4*{fa#4 <- `fa*`}, DATAS da#2*{da#2 <- `da*`}, ELEMS ea#2*{ea#2 <- `ea*`}, EXPORTS xi#2*{xi#2 <- `xi*`}}) + -- wf_module: `%`(MODULE_module(`%`_list(type#4*{type#4 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#4*{tag#4 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#7*{func#7 <- `func*`}), `%`_list(data#5*{data#5 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#4?{start#4 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) + -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- `tagtype*`} + -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- `expr_G*`, globaltype#125 <- `globaltype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- `memtype*`} + -- (wf_table: `%`(TABLE_table(tabletype#159, expr_T#2)))*{expr_T#2 <- `expr_T*`, tabletype#159 <- `tabletype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_func: `%`(FUNC_func(x#5, local#4*{local#4 <- `local*#85`}, expr_F#3)))*{expr_F#3 <- `expr_F*`, `local*#85` <- `local**`, x#5 <- `x*`} + -- if (|`expr_F*`| = |`local**`|) + -- if (|`expr_F*`| = |`x*`|) + -- (wf_data: `%`(DATA_data(byte#7*{byte#7 <- `byte*#113`}, datamode#112)))*{`byte*#113` <- `byte**`, datamode#112 <- `datamode*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_elem: `%`(ELEM_elem(elemtype#3, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)))*{elemmode#232 <- `elemmode*`, elemtype#3 <- `elemtype*`, `expr_E*#2` <- `expr_E**`} + -- if (|`elemmode*`| = |`elemtype*`|) + -- if (|`elemmode*`| = |`expr_E**`|) + -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#4*{aa_I#4 <- `aa_I*`} ++ aa#4*{aa#4 <- `aa*`}, GLOBALS ga_I#4*{ga_I#4 <- `ga_I*`} ++ ga#4*{ga#4 <- `ga*`}, MEMS ma_I#4*{ma_I#4 <- `ma_I*`} ++ ma#4*{ma#4 <- `ma*`}, TABLES ta_I#4*{ta_I#4 <- `ta_I*`} ++ ta#4*{ta#4 <- `ta*`}, FUNCS fa_I#4*{fa_I#4 <- `fa_I*`} ++ fa#5*{fa#5 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES dt#16*{dt#16 <- `dt*`}, TAGS aa_I#5*{aa_I#5 <- `aa_I*`} ++ aa#5*{aa#5 <- `aa*`}, GLOBALS ga_I#5*{ga_I#5 <- `ga_I*`} ++ ga#5*{ga#5 <- `ga*`}, MEMS ma_I#5*{ma_I#5 <- `ma_I*`} ++ ma#5*{ma#5 <- `ma*`}, TABLES ta_I#5*{ta_I#5 <- `ta_I*`} ++ ta#5*{ta#5 <- `ta*`}, FUNCS fa_I#5*{fa_I#5 <- `fa_I*`} ++ fa#6*{fa#6 <- `fa*`}, DATAS da#3*{da#3 <- `da*`}, ELEMS ea#3*{ea#3 <- `ea*`}, EXPORTS xi#3*{xi#3 <- `xi*`}}) + -- fun_allocfuncs: `%%%%%`(s_6, dt#14*{dt#14 <- `dt*`}[$proj_uN_0(x#3).0]*{x#3 <- `x*`}, FUNC_funccode(x#4, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#4 <- `x*`}, moduleinst^|func#6*{func#6 <- `func*`}|{}, var_17) + -- (if ($proj_uN_0(x#3).0 < |dt#14*{dt#14 <- `dt*`}|))*{x#3 <- `x*`} + -- (fun_subst_all_reftype: `%%%`(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#2 <- `elemtype*`} + -- if (|`var_16*`| = |`elemtype*`|) + -- fun_allocelems: `%%%%`(s_5, var_16*{var_16 <- `var_16*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_15) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#4*{data#4 <- `data*`}|{}, byte#6*{byte#6 <- `byte*#112`}*{`byte*#112` <- `byte**`}, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype#158, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#158 <- `tabletype*`} + -- if (|`var_13*`| = |`tabletype*`|) + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- (fun_subst_all_memtype: `%%%`(memtype#124, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#124 <- `memtype*`} + -- if (|`var_11*`| = |`memtype*`|) + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype#124, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#124 <- `globaltype*`} + -- if (|`var_9*`| = |`globaltype*`|) + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- (fun_subst_all_tagtype: `%%%`(tagtype#80, $typeuse_deftype(dt#9)*{dt#9 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#80 <- `tagtype*`} + -- if (|`var_7*`| = |`tagtype*`|) + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#3*{type#3 <- `type*`}, var_5) + -- fun_funcsxa: `%%`(externaddr#6*{externaddr#6 <- `externaddr*`}, var_4) + -- fun_tablesxa: `%%`(externaddr#5*{externaddr#5 <- `externaddr*`}, var_3) + -- fun_memsxa: `%%`(externaddr#4*{externaddr#4 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#3*{externaddr#3 <- `externaddr*`}, var_1) + -- fun_tagsxa: `%%`(externaddr#2*{externaddr#2 <- `externaddr*`}, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}(x, DATA_data(b^n{b <- `b*`}, ACTIVE_datamode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + rule allocmodule_is_wf_0{store : store, module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst), var_4 : (store, moduleinst)}: + `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = var_4) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + -- fun_allocmodule: `%%%%%%%`(store, module, var_0, var_1, var_2, var_3, var_4) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $runelem_(elemidx : elemidx, elem : elem) : instr* +relation fun_rundata_: `%%%`(dataidx, data, instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, PASSIVE_elemmode)) = [] + rule fun_rundata__case_0{x : uN, n : nat, `b*` : byte*}: + `%%%`(x, DATA_data(b#10*{b#10 <- `b*`}, PASSIVE_datamode), []) + -- if (n = |`b*`|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule fun_rundata__case_1{x : uN, n : nat, `b*` : byte*, y : uN, `instr*` : instr*}: + `%%%`(x, DATA_data(b#11*{b#11 <- `b*`}, ACTIVE_datamode(y, instr#7*{instr#7 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)]) + -- if (n = |`b*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(dataidx : dataidx, data : data, ret_val : instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}(x, ELEM_elem(rt, e^n{e <- `e*`}, ACTIVE_elemmode(y, instr*{instr <- `instr*`}))) = instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule rundata__is_wf_0{dataidx : dataidx, data : data, ret_val : instr*, var_0 : instr*}: + `%%%`(dataidx, data, ret_val) + -- wf_uN: `%%`(32, dataidx) + -- wf_data: `%`(data) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_rundata_: `%%%`(dataidx, data, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_runelem_: `%%%`(elemidx, elem, instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_0{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#1*{e#1 <- `e*`}, PASSIVE_elemmode), []) + -- if (n = |`e*`|) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_1{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#2*{e#2 <- `e*`}, DECLARE_elemmode), [`ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_2{x : uN, rt : reftype, n : nat, `e*` : expr*, y : uN, `instr*` : instr*}: + `%%%`(x, ELEM_elem(rt, e#3*{e#3 <- `e*`}, ACTIVE_elemmode(y, instr#8*{instr#8 <- `instr*`})), instr*{instr <- `instr*`} ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)]) + -- if (n = |`e*`|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(elemidx : elemidx, elem : elem, ret_val : instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule runelem__is_wf_0{elemidx : elemidx, elem : elem, ret_val : instr*, var_0 : instr*}: + `%%%`(elemidx, elem, ret_val) + -- wf_uN: `%%`(32, elemidx) + -- wf_elem: `%`(elem) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_runelem_: `%%%`(elemidx, elem, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.1-160.92 -def $evalexprs(state : state, expr*) : (state, ref*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:161.1-161.34 - def $evalexprs{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:162.1-165.46 - def $evalexprs{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state}(z, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [ref] ++ ref'*{ref' <- `ref'*`}) - -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) - -- let{z'' : state, `ref'*` : ref*} (z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`}) - -- wf_ref: `%`(ref) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, ref : ref, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) + -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) + -- let{z'' : state, `ref'*` : ref*} (z'', ref'#5*{ref'#5 <- `ref'*`}) = var_0 -- wf_state: `%`(z') + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{state : state, var_0 : expr*, ret_val : (state, ref*), var_1 : (state, ref*)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} + -- fun_evalexprs: `%%%`(state, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, var_1 : (state, ref**), var_0 : (state, ref*)}: + `%%%`(z, [expr#365*{expr#365 <- `expr*`}] ++ expr'#3*{expr'#3 <- `expr'*#1`}*{`expr'*#1` <- `expr'**`}, (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`})) + -- let{`ref*` : ref*, z' : state} (z', ref#6*{ref#6 <- `ref*`}) = var_0 + -- let{z'' : state, `ref'**` : ref**} (z'', ref'#6*{ref'#6 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`}) = var_1 + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 -def $evalexprss(state : state, expr**) : (state, ref**) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 - def $evalexprss{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:169.1-172.49 - def $evalexprss{z : state, `expr*` : expr*, `expr'**` : expr**}(z, [expr*{expr <- `expr*`}] ++ expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) - -- let{`ref*` : ref*, z' : state} (z', ref*{ref <- `ref*`}) = $evalexprs(z, expr*{expr <- `expr*`}) - -- let{z'' : state, `ref'**` : ref**} (z'', ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = $evalexprss(z', expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{state : state, var_0 : expr**, ret_val : (state, ref**), var_1 : (state, ref**)}: + `%%%`(state, var_0, ret_val) + -- wf_state: `%`(state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} + -- fun_evalexprss: `%%%`(state, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 -def $evalglobals(state : state, globaltype*, expr*) : (state, val*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 - def $evalglobals{z : state}(z, [], []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:176.1-181.82 - def $evalglobals{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state}(z, [gt] ++ gt'*{gt' <- `gt'*`}, [expr] ++ expr'*{expr' <- `expr'*`}) = (z'', [val] ++ val'*{val' <- `val'*`}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_0{z : state}: + `%%%%`(z, [], [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, val : val, z' : state, var_1 : (state, val*), var_0 : (store, globaladdr)}: + `%%%%`(z, [gt] ++ gt'#1*{gt'#1 <- `gt'*`}, [expr] ++ expr'#5*{expr'#5 <- `expr'*`}, (z'', [val] ++ val'*{val' <- `val'*`})) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) -- let{s : store, f : frame} `%;%`_state(s, f) = z' - -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, val) - -- let{z'' : state, `val'*` : val*} (z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`}) - -- wf_val: `%`(val) + -- let{s' : store, a : addr} (s', a) = var_0 + -- let{z'' : state, `val'*` : val*} (z'', val'#3*{val'#3 <- `val'*`}) = var_1 -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- fun_evalglobals: `%%%%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, gt, val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*), var_2 : (state, val*)}: + `%%%%`(state, var_0, var_1, ret_val) + -- wf_state: `%`(state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} + -- fun_evalglobals: `%%%%`(state, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $instantiate(store : store, module : module, externaddr*) : config +relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $instantiate{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, module, externaddr*{externaddr <- `externaddr*`}) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`})) - -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- (Externaddr_ok: `%|-%:%`(s, externaddr, xt_I))*{externaddr <- `externaddr*`, xt_I <- `xt_I*`} - -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) = module - -- if (global*{global <- `global*`} = GLOBAL_global(globaltype, expr_G)*{expr_G <- `expr_G*`, globaltype <- `globaltype*`}) - -- if (table*{table <- `table*`} = TABLE_table(tabletype, expr_T)*{expr_T <- `expr_T*`, tabletype <- `tabletype*`}) - -- if (data*{data <- `data*`} = DATA_data(byte*{byte <- `byte*`}, datamode)*{`byte*` <- `byte**`, datamode <- `datamode*`}) - -- if (elem*{elem <- `elem*`} = ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`}) - -- if (start?{start <- `start?`} = START_start(x)?{x <- `x?`}) - -- if (moduleinst_0 = {TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, `xt_I*` : externtype*, `xt_E*` : externtype*, `expr_G*` : expr*, `globaltype*` : globaltype*, `expr_T*` : expr*, `tabletype*` : tabletype*, `byte**` : byte**, `datamode*` : datamode*, `elemmode*` : elemmode*, `expr_E**` : expr**, `reftype*` : reftype*, `x?` : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat, var_11 : funcaddr*, var_10 : globaladdr*, var_9 : deftype*, `var_8*` : instr**, `var_7*` : instr**, var_6 : (store, moduleinst), var_5 : (state, ref**), var_4 : (state, ref*), var_3 : (state, val*), var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: + `%%%%`(s, module, externaddr#7*{externaddr#7 <- `externaddr*`}, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) + -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) + -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- `externaddr*`, xt_I#2 <- `xt_I*`} + -- if (|`externaddr*`| = |`xt_I*`|) + -- let{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*} MODULE_module(`%`_list(type#5*{type#5 <- `type*`}), `%`_list(import#4*{import#4 <- `import*`}), `%`_list(tag#5*{tag#5 <- `tag*`}), `%`_list(global#6*{global#6 <- `global*`}), `%`_list(mem#6*{mem#6 <- `mem*`}), `%`_list(table#6*{table#6 <- `table*`}), `%`_list(func#8*{func#8 <- `func*`}), `%`_list(data#6*{data#6 <- `data*`}), `%`_list(elem#6*{elem#6 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#7*{export#7 <- `export*`})) = module + -- if (global#7*{global#7 <- `global*`} = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`}) + -- if (table#7*{table#7 <- `table*`} = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`}) + -- if (data#7*{data#7 <- `data*`} = DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`}) + -- if (elem#7*{elem#7 <- `elem*`} = ELEM_elem(reftype#516, expr_E#3*{expr_E#3 <- `expr_E*#3`}, elemmode#237)*{elemmode#237 <- `elemmode*`, `expr_E*#3` <- `expr_E**`, reftype#516 <- `reftype*`}) + -- if (start#6?{start#6 <- `start?`} = START_start(x#6)?{x#6 <- `x?`}) + -- if (moduleinst_0 = {TYPES var_0, TAGS [], GLOBALS var_1, MEMS [], TABLES [], FUNCS var_2 ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- let{z' : state, `val_G*` : val*} (z', val_G*{val_G <- `val_G*`}) = $evalglobals(z, globaltype*{globaltype <- `globaltype*`}, expr_G*{expr_G <- `expr_G*`}) - -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T*{ref_T <- `ref_T*`}) = $evalexprs(z', expr_T*{expr_T <- `expr_T*`}) - -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = $evalexprss(z'', expr_E*{expr_E <- `expr_E*`}*{`expr_E*` <- `expr_E**`}) + -- let{z' : state, `val_G*` : val*} (z', val_G#3*{val_G#3 <- `val_G*`}) = var_3 + -- let{z'' : state, `ref_T*` : ref*} (z'', ref_T#3*{ref_T#3 <- `ref_T*`}) = var_4 + -- let{z''' : state, `ref_E**` : ref**} (z''', ref_E#3*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`}) = var_5 -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' - -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = $allocmodule(s''', module, externaddr*{externaddr <- `externaddr*`}, val_G*{val_G <- `val_G*`}, ref_T*{ref_T <- `ref_T*`}, ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) - -- let{`instr_D*` : instr*} instr_D*{instr_D <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D), data*{data <- `data*`}[i_D])^(i_D<|data*{data <- `data*`}|){}) - -- let{`instr_E*` : instr*} instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){}) - -- let{`instr_S?` : instr?} instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`} + -- let{s'''' : store, moduleinst : moduleinst} (s'''', moduleinst) = var_6 + -- let{`instr_D*` : instr*} instr_D#1*{instr_D#1 <- `instr_D*`} = $concat_(syntax instr, var_7^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`}) + -- let{`instr_E*` : instr*} instr_E#1*{instr_E#1 <- `instr_E*`} = $concat_(syntax instr, var_8^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`}) + -- let{`instr_S?` : instr?} instr_S#1?{instr_S#1 <- `instr_S?`} = CALL_instr(x#7)?{x#7 <- `x?`} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E*{instr_E <- `instr_E*`} ++ instr_D*{instr_D <- `instr_D*`} ++ lift(instr_S?{instr_S <- `instr_S?`}))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I*{xt_I <- `xt_I*`}, xt_E*{xt_E <- `xt_E*`})) - -- wf_module: `%`(MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`}))) - -- (wf_global: `%`(GLOBAL_global(globaltype, expr_G)))*{expr_G <- `expr_G*`, globaltype <- `globaltype*`} - -- (wf_table: `%`(TABLE_table(tabletype, expr_T)))*{expr_T <- `expr_T*`, tabletype <- `tabletype*`} - -- (wf_data: `%`(DATA_data(byte*{byte <- `byte*`}, datamode)))*{`byte*` <- `byte**`, datamode <- `datamode*`} - -- (wf_elem: `%`(ELEM_elem(reftype, expr_E*{expr_E <- `expr_E*`}, elemmode)))*{elemmode <- `elemmode*`, `expr_E*` <- `expr_E**`, reftype <- `reftype*`} - -- (wf_start: `%`(START_start(x)))?{x <- `x?`} - -- wf_moduleinst: `%`({TYPES $alloctypes(type*{type <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr*{externaddr <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr*{externaddr <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#3*{xt_I#3 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) + -- wf_module: `%`(MODULE_module(`%`_list(type#7*{type#7 <- `type*`}), `%`_list(import#5*{import#5 <- `import*`}), `%`_list(tag#6*{tag#6 <- `tag*`}), `%`_list(global#8*{global#8 <- `global*`}), `%`_list(mem#7*{mem#7 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#10*{data#10 <- `data*`}), `%`_list(elem#10*{elem#10 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#8*{export#8 <- `export*`}))) + -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- `expr_G*`, globaltype#130 <- `globaltype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- `expr_T*`, tabletype#163 <- `tabletype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_data: `%`(DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)))*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_elem: `%`(ELEM_elem(reftype#518, expr_E#5*{expr_E#5 <- `expr_E*#5`}, elemmode#239)))*{elemmode#239 <- `elemmode*`, `expr_E*#5` <- `expr_E**`, reftype#518 <- `reftype*`} + -- if (|`elemmode*`| = |`expr_E**`|) + -- if (|`elemmode*`| = |`reftype*`|) + -- (wf_start: `%`(START_start(x#8)))?{x#8 <- `x?`} + -- wf_moduleinst: `%`({TYPES var_9, TAGS [], GLOBALS var_10, MEMS [], TABLES [], FUNCS var_11 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) - -- (wf_uN: `%%`(32, `%`_uN(i_D)))^(i_D<|data*{data <- `data*`}|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E)))^(i_E<|elem*{elem <- `elem*`}|){} - -- (wf_instr: `%`(CALL_instr(x)))?{x <- `x?`} + -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data#11*{data#11 <- `data*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- `x?`} + -- fun_funcsxa: `%%`(externaddr#13*{externaddr#13 <- `externaddr*`}, var_11) + -- fun_globalsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_10) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_9) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#1), elem#9*{elem#9 <- `elem*`}[i_E#1], var_8))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){var_8 <- `var_8*`} + -- (if (i_E#1 < |elem#9*{elem#9 <- `elem*`}|))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#1), data#9*{data#9 <- `data*`}[i_D#1], var_7))^(i_D#1<|data#8*{data#8 <- `data*`}|){var_7 <- `var_7*`} + -- (if (i_D#1 < |data#9*{data#9 <- `data*`}|))^(i_D#1<|data#8*{data#8 <- `data*`}|){} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#11*{externaddr#11 <- `externaddr*`}, val_G#4*{val_G#4 <- `val_G*`}, ref_T#4*{ref_T#4 <- `ref_T*`}, ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}, var_6) + -- fun_evalexprss: `%%%`(z'', expr_E#4*{expr_E#4 <- `expr_E*#4`}*{`expr_E*#4` <- `expr_E**`}, var_5) + -- fun_evalexprs: `%%%`(z', expr_T#4*{expr_T#4 <- `expr_T*`}, var_4) + -- fun_evalglobals: `%%%%`(z, globaltype#129*{globaltype#129 <- `globaltype*`}, expr_G#4*{expr_G#4 <- `expr_G*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#10*{externaddr#10 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config +relation instantiate_is_wf: `%%%%`(store : store, module : module, var_0 : externaddr*, ret_val : config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $invoke{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}(s, funcaddr, val*{val <- `val*`}) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))]) - -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (Val_ok: `%|-%:%`(s, val, t_1))*{t_1 <- `t_1*`, val <- `val*`} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), (val : val <: instr)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr((s.FUNCS_store[funcaddr].TYPE_funcinst : deftype <: typeuse))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + rule instantiate_is_wf_0{store : store, module : module, var_0 : externaddr*, ret_val : config, var_1 : config}: + `%%%%`(store, module, var_0, ret_val) + -- wf_store: `%`(store) + -- wf_module: `%`(module) + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_instantiate: `%%%%`(store, module, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_invoke: `%%%%`(store, funcaddr, val*, config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_invoke_case_0{s : store, funcaddr : nat, `val*` : val*, `t_1*` : valtype*, `t_2*` : valtype*}: + `%%%%`(s, funcaddr, val#1*{val#1 <- `val*`}, `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val)*{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- if (funcaddr < |s.FUNCS_store|) + -- (Val_ok: `%|-%:%`(s, val#2, t_1#5))*{t_1#5 <- `t_1*`, val#2 <- `val*`} + -- if (|`t_1*`| = |`val*`|) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `t_2*`}))) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation invoke_is_wf: `%%%%`(store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule invoke_is_wf_0{store : store, funcaddr : funcaddr, var_0 : val*, ret_val : config, var_1 : config}: + `%%%%`(store, funcaddr, var_0, ret_val) + -- wf_store: `%`(store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_invoke: `%%%%`(store, funcaddr, var_0, var_1) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -12232,6 +19982,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{N : N, rat : rat, ret_val : fNmag}: + `%%%`(N, rat, ret_val) + -- if (ret_val = $ieee_(N, rat)) + -- wf_fNmag: `%%`(N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -12272,13 +20030,30 @@ syntax I = idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.1-154.56 -def $concat_idctxt(idctxt*) : idctxt - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 - def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 - def $concat_idctxt{I : idctxt, `I'*` : I*}([I] ++ I'*{I' <- `I'*`}) = I +++ $concat_idctxt(I'*{I' <- `I'*`}) +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation fun_concat_idctxt: `%%`(idctxt*, idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_0: + `%%`([], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_1{I : idctxt, `I'*` : I*, var_0 : idctxt}: + `%%`([I] ++ I'#1*{I'#1 <- `I'*`}, I +++ var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt, var_1 : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_idctxt: `%`(ret_val) + -- fun_concat_idctxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -12299,6 +20074,17 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])))*{`field*` <- `field**`} -- if ([?(`%`_name(field*{field <- `field*`}))*{`field*` <- `field**`}] = I.FIELDS_I) -- wf_idctxt: `%`(I) + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(`%`_name(field*{field <- `field*`}))])}*{`field*` <- `field**`} -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12318,6 +20104,39 @@ syntax decl = | START(funcidx : funcidx) | EXPORT(name : name, externidx : externidx) +def $decl_data(data) : decl + def $decl_data{x0 : byte*, x1 : datamode}(DATA_data(x0, x1)) = DATA_decl(x0, x1) + +def $decl_elem(elem) : decl + def $decl_elem{x0 : reftype, x1 : expr*, x2 : elemmode}(ELEM_elem(x0, x1, x2)) = ELEM_decl(x0, x1, x2) + +def $decl_export(export) : decl + def $decl_export{x0 : name, x1 : externidx}(EXPORT_export(x0, x1)) = EXPORT_decl(x0, x1) + +def $decl_func(func) : decl + def $decl_func{x0 : typeidx, x1 : local*, x2 : expr}(FUNC_func(x0, x1, x2)) = FUNC_decl(x0, x1, x2) + +def $decl_global(global) : decl + def $decl_global{x0 : globaltype, x1 : expr}(GLOBAL_global(x0, x1)) = GLOBAL_decl(x0, x1) + +def $decl_import(import) : decl + def $decl_import{x0 : name, x1 : name, x2 : externtype}(IMPORT_import(x0, x1, x2)) = IMPORT_decl(x0, x1, x2) + +def $decl_mem(mem) : decl + def $decl_mem{x0 : memtype}(MEMORY_mem(x0)) = MEMORY_decl(x0) + +def $decl_start(start) : decl + def $decl_start{x0 : funcidx}(START_start(x0)) = START_decl(x0) + +def $decl_table(table) : decl + def $decl_table{x0 : tabletype, x1 : expr}(TABLE_table(x0, x1)) = TABLE_decl(x0, x1) + +def $decl_tag(tag) : decl + def $decl_tag{x0 : tagtype}(TAG_tag(x0)) = TAG_decl(x0) + +def $decl_type(type) : decl + def $decl_type{x0 : rectype}(TYPE_type(x0)) = TYPE_decl(x0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec @@ -12387,160 +20206,387 @@ relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.1-258.76 -def $typesd(decl*) : type* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:270.1-270.23 - def $typesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:271.1-271.48 - def $typesd{type : type, `decl'*` : decl*}([(type : type <: decl)] ++ decl'*{decl' <- `decl'*`}) = [type] ++ $typesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:272.1-272.57 - def $typesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $typesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 +relation fun_typesd: `%%`(decl*, type*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_1{rectype : rectype, `decl'*` : decl*, var_0 : type*}: + `%%`([TYPE_decl(rectype)] ++ decl'#1*{decl'#1 <- `decl'*`}, [TYPE_type(rectype)] ++ var_0) + -- fun_typesd: `%%`(decl'#2*{decl'#2 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_2{decl : decl, `decl'*` : decl*, var_0 : type*}: + `%%`([decl] ++ decl'#3*{decl'#3 <- `decl'*`}, var_0) + -- fun_typesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation fun_importsd: `%%`(decl*, import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_1{name : name, name_0 : name, externtype : externtype, `decl'*` : decl*, var_0 : import*}: + `%%`([IMPORT_decl(name, name_0, externtype)] ++ decl'#4*{decl'#4 <- `decl'*`}, [IMPORT_import(name, name_0, externtype)] ++ var_0) + -- fun_importsd: `%%`(decl'#5*{decl'#5 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_2{decl : decl, `decl'*` : decl*, var_0 : import*}: + `%%`([decl] ++ decl'#6*{decl'#6 <- `decl'*`}, var_0) + -- fun_importsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*, var_1 : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} + -- fun_importsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation fun_tagsd: `%%`(decl*, tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_1{tagtype : tagtype, `decl'*` : decl*, var_0 : tag*}: + `%%`([TAG_decl(tagtype)] ++ decl'#7*{decl'#7 <- `decl'*`}, [TAG_tag(tagtype)] ++ var_0) + -- fun_tagsd: `%%`(decl'#8*{decl'#8 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_2{decl : decl, `decl'*` : decl*, var_0 : tag*}: + `%%`([decl] ++ decl'#9*{decl'#9 <- `decl'*`}, var_0) + -- fun_tagsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*, var_1 : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tagsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation fun_globalsd: `%%`(decl*, global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_1{globaltype : globaltype, expr : expr, `decl'*` : decl*, var_0 : global*}: + `%%`([GLOBAL_decl(globaltype, expr)] ++ decl'#10*{decl'#10 <- `decl'*`}, [GLOBAL_global(globaltype, expr)] ++ var_0) + -- fun_globalsd: `%%`(decl'#11*{decl'#11 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_2{decl : decl, `decl'*` : decl*, var_0 : global*}: + `%%`([decl] ++ decl'#12*{decl'#12 <- `decl'*`}, var_0) + -- fun_globalsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*, var_1 : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation fun_memsd: `%%`(decl*, mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_1{memtype : memtype, `decl'*` : decl*, var_0 : mem*}: + `%%`([MEMORY_decl(memtype)] ++ decl'#13*{decl'#13 <- `decl'*`}, [MEMORY_mem(memtype)] ++ var_0) + -- fun_memsd: `%%`(decl'#14*{decl'#14 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_2{decl : decl, `decl'*` : decl*, var_0 : mem*}: + `%%`([decl] ++ decl'#15*{decl'#15 <- `decl'*`}, var_0) + -- fun_memsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*, var_1 : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation fun_tablesd: `%%`(decl*, table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_1{tabletype : tabletype, expr : expr, `decl'*` : decl*, var_0 : table*}: + `%%`([TABLE_decl(tabletype, expr)] ++ decl'#16*{decl'#16 <- `decl'*`}, [TABLE_table(tabletype, expr)] ++ var_0) + -- fun_tablesd: `%%`(decl'#17*{decl'#17 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_2{decl : decl, `decl'*` : decl*, var_0 : table*}: + `%%`([decl] ++ decl'#18*{decl'#18 <- `decl'*`}, var_0) + -- fun_tablesd: `%%`(decl'*{decl' <- `decl'*`}, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*, var_1 : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.1-259.78 -def $importsd(decl*) : import* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:274.1-274.25 - def $importsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:275.1-275.56 - def $importsd{import : import, `decl'*` : decl*}([(import : import <: decl)] ++ decl'*{decl' <- `decl'*`}) = [import] ++ $importsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:276.1-276.61 - def $importsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $importsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation fun_funcsd: `%%`(decl*, func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_1{typeidx : typeidx, `local*` : local*, expr : expr, `decl'*` : decl*, var_0 : func*}: + `%%`([FUNC_decl(typeidx, `local*`, expr)] ++ decl'#19*{decl'#19 <- `decl'*`}, [FUNC_func(typeidx, `local*`, expr)] ++ var_0) + -- fun_funcsd: `%%`(decl'#20*{decl'#20 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_2{decl : decl, `decl'*` : decl*, var_0 : func*}: + `%%`([decl] ++ decl'#21*{decl'#21 <- `decl'*`}, var_0) + -- fun_funcsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 -def $tagsd(decl*) : tag* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 - def $tagsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:279.1-279.44 - def $tagsd{tag : tag, `decl'*` : decl*}([(tag : tag <: decl)] ++ decl'*{decl' <- `decl'*`}) = [tag] ++ $tagsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:280.1-280.55 - def $tagsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tagsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*, var_1 : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} + -- fun_funcsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 -def $globalsd(decl*) : global* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 - def $globalsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:283.1-283.56 - def $globalsd{global : global, `decl'*` : decl*}([(global : global <: decl)] ++ decl'*{decl' <- `decl'*`}) = [global] ++ $globalsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:284.1-284.61 - def $globalsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $globalsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation fun_datasd: `%%`(decl*, data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_1{`byte*` : byte*, datamode : datamode, `decl'*` : decl*, var_0 : data*}: + `%%`([DATA_decl(`byte*`, datamode)] ++ decl'#22*{decl'#22 <- `decl'*`}, [DATA_data(`byte*`, datamode)] ++ var_0) + -- fun_datasd: `%%`(decl'#23*{decl'#23 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_2{decl : decl, `decl'*` : decl*, var_0 : data*}: + `%%`([decl] ++ decl'#24*{decl'#24 <- `decl'*`}, var_0) + -- fun_datasd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 -def $memsd(decl*) : mem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 - def $memsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:287.1-287.44 - def $memsd{mem : mem, `decl'*` : decl*}([(mem : mem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [mem] ++ $memsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:288.1-288.55 - def $memsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $memsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*, var_1 : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} + -- fun_datasd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 -def $tablesd(decl*) : table* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 - def $tablesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:291.1-291.52 - def $tablesd{table : table, `decl'*` : decl*}([(table : table <: decl)] ++ decl'*{decl' <- `decl'*`}) = [table] ++ $tablesd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:292.1-292.59 - def $tablesd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $tablesd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation fun_elemsd: `%%`(decl*, elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_1{reftype : reftype, `expr*` : expr*, elemmode : elemmode, `decl'*` : decl*, var_0 : elem*}: + `%%`([ELEM_decl(reftype, `expr*`, elemmode)] ++ decl'#25*{decl'#25 <- `decl'*`}, [ELEM_elem(reftype, `expr*`, elemmode)] ++ var_0) + -- fun_elemsd: `%%`(decl'#26*{decl'#26 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_2{decl : decl, `decl'*` : decl*, var_0 : elem*}: + `%%`([decl] ++ decl'#27*{decl'#27 <- `decl'*`}, var_0) + -- fun_elemsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 -def $funcsd(decl*) : func* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 - def $funcsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:295.1-295.48 - def $funcsd{func : func, `decl'*` : decl*}([(func : func <: decl)] ++ decl'*{decl' <- `decl'*`}) = [func] ++ $funcsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:296.1-296.57 - def $funcsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $funcsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*, var_1 : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_elemsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 -def $datasd(decl*) : data* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 - def $datasd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:299.1-299.48 - def $datasd{data : data, `decl'*` : decl*}([(data : data <: decl)] ++ decl'*{decl' <- `decl'*`}) = [data] ++ $datasd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:300.1-300.57 - def $datasd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $datasd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation fun_startsd: `%%`(decl*, start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_1{funcidx : funcidx, `decl'*` : decl*, var_0 : start*}: + `%%`([START_decl(funcidx)] ++ decl'#28*{decl'#28 <- `decl'*`}, [START_start(funcidx)] ++ var_0) + -- fun_startsd: `%%`(decl'#29*{decl'#29 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_2{decl : decl, `decl'*` : decl*, var_0 : start*}: + `%%`([decl] ++ decl'#30*{decl'#30 <- `decl'*`}, var_0) + -- fun_startsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 -def $elemsd(decl*) : elem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 - def $elemsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:303.1-303.48 - def $elemsd{elem : elem, `decl'*` : decl*}([(elem : elem <: decl)] ++ decl'*{decl' <- `decl'*`}) = [elem] ++ $elemsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:304.1-304.57 - def $elemsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $elemsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*, var_1 : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} + -- fun_startsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 -def $startsd(decl*) : start* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 - def $startsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:307.1-307.52 - def $startsd{start : start, `decl'*` : decl*}([(start : start <: decl)] ++ decl'*{decl' <- `decl'*`}) = [start] ++ $startsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:308.1-308.59 - def $startsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $startsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation fun_exportsd: `%%`(decl*, export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_1{name : name, externidx : externidx, `decl'*` : decl*, var_0 : export*}: + `%%`([EXPORT_decl(name, externidx)] ++ decl'#31*{decl'#31 <- `decl'*`}, [EXPORT_export(name, externidx)] ++ var_0) + -- fun_exportsd: `%%`(decl'#32*{decl'#32 <- `decl'*`}, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_2{decl : decl, `decl'*` : decl*, var_0 : export*}: + `%%`([decl] ++ decl'#33*{decl'#33 <- `decl'*`}, var_0) + -- fun_exportsd: `%%`(decl'*{decl' <- `decl'*`}, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 -def $exportsd(decl*) : export* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 - def $exportsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:311.1-311.56 - def $exportsd{export : export, `decl'*` : decl*}([(export : export <: decl)] ++ decl'*{decl' <- `decl'*`}) = [export] ++ $exportsd(decl'*{decl' <- `decl'*`}) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:312.1-312.61 - def $exportsd{decl : decl, `decl'*` : decl*}([decl] ++ decl'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*, var_1 : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} + -- fun_exportsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(decl*) : bool +relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl*` : decl*}(decl*{decl <- `decl*`}) = true - -- if ($importsd(decl*{decl <- `decl*`}) = []) + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) + -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{`decl_1*` : decl*, import : import, `decl_2*` : decl*}(decl_1*{decl_1 <- `decl_1*`} ++ [(import : import <: decl)] ++ decl_2*{decl_2 <- `decl_2*`}) = (((((($importsd(decl_1*{decl_1 <- `decl_1*`}) = []) /\ ($tagsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($globalsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($memsd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($tablesd(decl_1*{decl_1 <- `decl_1*`}) = [])) /\ ($funcsd(decl_1*{decl_1 <- `decl_1*`}) = [])) + rule fun_ordered_case_1{name : name, name_0 : name, externtype : externtype, `decl_1*` : decl*, `decl_2*` : decl*, var_5 : func*, var_4 : table*, var_3 : mem*, var_2 : global*, var_1 : tag*, var_0 : import*}: + `%%`(decl_1#1*{decl_1#1 <- `decl_1*`} ++ [IMPORT_decl(name, name_0, externtype)] ++ decl_2#1*{decl_2#1 <- `decl_2*`}, ((((((var_0 = []) /\ (var_1 = [])) /\ (var_2 = [])) /\ (var_3 = [])) /\ (var_4 = [])) /\ (var_5 = []))) + -- fun_funcsd: `%%`(decl_1#2*{decl_1#2 <- `decl_1*`}, var_5) + -- fun_tablesd: `%%`(decl_1#3*{decl_1#3 <- `decl_1*`}, var_4) + -- fun_memsd: `%%`(decl_1#4*{decl_1#4 <- `decl_1*`}, var_3) + -- fun_globalsd: `%%`(decl_1#5*{decl_1#5 <- `decl_1*`}, var_2) + -- fun_tagsd: `%%`(decl_1#6*{decl_1#6 <- `decl_1*`}, var_1) + -- fun_importsd: `%%`(decl_1#7*{decl_1#7 <- `decl_1*`}, var_0) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec rule _{C : context, n : n, `dt*` : deftype*, `jt*` : tagtype*, `gt*` : globaltype*, `mt*` : memtype*, `tt*` : tabletype*, `dt_F*` : deftype*, `ok*` : datatype*, `et*` : elemtype*, `lct*` : localtype*, `rt*` : reftype*, `rt'?` : reftype?, `x*` : idx*, m : m, `st*` : subtype*, C_0 : context, `t_1*` : valtype*, `t_2*` : valtype*}: `|-%:OK`(C) - -- if (C = {TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) + -- if (C = {TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- if (C_0 = {TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (Deftype_ok: `%|-%:OK`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- `dt_F*`, t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (|`dt_F*`| = |`t_1*`|) + -- if (|`dt_F*`| = |`t_2*`|) -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt : reftype <: valtype)])))*{rt <- `rt*`} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([(rt' : reftype <: valtype)])))?{rt' <- `rt'?`} - -- (if (x!`%`_uN.0 < |dt_F*{dt_F <- `dt_F*`}|))*{x <- `x*`} + -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt)])))*{rt <- `rt*`} + -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt')])))?{rt' <- `rt'?`} + -- (if ($proj_uN_0(x).0 < |dt_F*{dt_F <- `dt_F*`}|))*{x <- `x*`} -- wf_context: `%`(C) -- wf_context: `%`(C_0) - -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype((rt : reftype <: valtype)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift((rt' : reftype <: valtype)?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) + -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS jt*{jt <- `jt*`}, GLOBALS gt*{gt <- `gt*`}, MEMS mt*{mt <- `mt*`}, TABLES tt*{tt <- `tt*`}, FUNCS dt_F*{dt_F <- `dt_F*`}, DATAS ok*{ok <- `ok*`}, ELEMS et*{et <- `et*`}, LOCALS lct*{lct <- `lct*`}, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- `rt*`})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- `rt'?`}))), REFS x*{x <- `x*`}, RECS st^m{st <- `st*`}}) -- wf_context: `%`({TYPES dt^n{dt <- `dt*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) - -- (wf_context: `%`({TYPES dt^n{dt <- `dt*`}[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- `t_1*`, t_2 <- `t_2*`} + -- if (|`t_1*`| = |`t_2*`|) + -- if (n = |`dt*`|) + -- if (m = |`st*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) @@ -12615,22 +20666,32 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) `%|-%:%`(s, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}, {TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(tagaddr), TAG_externtype(tagtype)))*{tagaddr <- `tagaddr*`, tagtype <- `tagtype*`} + -- if (|`tagaddr*`| = |`tagtype*`|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(globaladdr), GLOBAL_externtype(globaltype)))*{globaladdr <- `globaladdr*`, globaltype <- `globaltype*`} - -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} + -- if (|`globaladdr*`| = |`globaltype*`|) + -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(funcaddr), FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`, funcaddr <- `funcaddr*`} + -- if (|`deftype_F*`| = |`funcaddr*`|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(memaddr), MEM_externtype(memtype)))*{memaddr <- `memaddr*`, memtype <- `memtype*`} + -- if (|`memaddr*`| = |`memtype*`|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(tableaddr), TABLE_externtype(tabletype)))*{tableaddr <- `tableaddr*`, tabletype <- `tabletype*`} + -- if (|`tableaddr*`| = |`tabletype*`|) -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[dataaddr], datatype))*{dataaddr <- `dataaddr*`, datatype <- `datatype*`} + -- if (|`dataaddr*`| = |`datatype*`|) + -- (if (dataaddr < |s.DATAS_store|))*{dataaddr <- `dataaddr*`} -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[elemaddr], elemtype))*{elemaddr <- `elemaddr*`, elemtype <- `elemtype*`} + -- if (|`elemaddr*`| = |`elemtype*`|) + -- (if (elemaddr < |s.ELEMS_store|))*{elemaddr <- `elemaddr*`} -- (Exportinst_ok: `%|-%:OK`(s, exportinst))*{exportinst <- `exportinst*`} -- if $disjoint_(syntax name, exportinst.NAME_exportinst*{exportinst <- `exportinst*`}) -- (if (exportinst.ADDR_exportinst <- TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}))*{exportinst <- `exportinst*`} + -- if (|TAG_externaddr(tagaddr)*{tagaddr <- `tagaddr*`} ++ GLOBAL_externaddr(globaladdr)*{globaladdr <- `globaladdr*`} ++ MEM_externaddr(memaddr)*{memaddr <- `memaddr*`} ++ TABLE_externaddr(tableaddr)*{tableaddr <- `tableaddr*`} ++ FUNC_externaddr(funcaddr)*{funcaddr <- `funcaddr*`}| > 0) -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagaddr*{tagaddr <- `tagaddr*`}, GLOBALS globaladdr*{globaladdr <- `globaladdr*`}, MEMS memaddr*{memaddr <- `memaddr*`}, TABLES tableaddr*{tableaddr <- `tableaddr*`}, FUNCS funcaddr*{funcaddr <- `funcaddr*`}, DATAS dataaddr*{dataaddr <- `dataaddr*`}, ELEMS elemaddr*{elemaddr <- `elemaddr*`}, EXPORTS exportinst*{exportinst <- `exportinst*`}}) -- wf_context: `%`({TYPES deftype*{deftype <- `deftype*`}, TAGS tagtype*{tagtype <- `tagtype*`}, GLOBALS globaltype*{globaltype <- `globaltype*`}, MEMS memtype*{memtype <- `memtype*`}, TABLES tabletype*{tabletype <- `tabletype*`}, FUNCS deftype_F*{deftype_F <- `deftype_F*`}, DATAS datatype*{datatype <- `datatype*`}, ELEMS elemtype*{elemtype <- `elemtype*`}, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr*{funcaddr <- `funcaddr*`}|){}, RECS subtype*{subtype <- `subtype*`}}) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_externtype: `%`(TAG_externtype(tagtype)))*{tagtype <- `tagtype*`} -- (wf_externtype: `%`(GLOBAL_externtype(globaltype)))*{globaltype <- `globaltype*`} - -- (wf_externtype: `%`(FUNC_externtype((deftype_F : deftype <: typeuse))))*{deftype_F <- `deftype_F*`} + -- (wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`} -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} @@ -12641,6 +20702,7 @@ relation Frame_ok: `%|-%:%`(store, frame, context) `%|-%:%`(s, {LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct*{lct <- `lct*`}, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} + -- if (|`lct*`| = |`val?*`|) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_frame: `%`({LOCALS val?{val <- `val?`}*{`val?` <- `val?*`}, MODULE moduleinst}) @@ -12662,12 +20724,12 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:14.1-16.27 rule ref{s : store, C : context, ref : ref, rt : reftype}: - `%;%|-%:%`(s, C, (ref : ref <: instr), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + `%;%|-%:%`(s, C, $instr_ref(ref), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- Ref_ok: `%|-%:%`(s, ref, rt) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_ref: `%`(ref) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(rt : reftype <: valtype)]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:18.1-21.68 rule label{s : store, C : context, n : n, `instr'*` : instr*, `instr*` : instr*, `t*` : valtype*, `t'*` : valtype*, `x'*` : idx*, `x*` : idx*}: @@ -12681,6 +20743,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'^n{t' <- `t'*`}), x'*{x' <- `x'*`}, `%`_resulttype(t*{t <- `t*`}))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'^n{t' <- `t'*`})], RETURN ?(), REFS [], RECS []}) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x*{x <- `x*`}, `%`_resulttype(t*{t <- `t*`}))) + -- if (n = |`t'*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, n : n, f : frame, `instr*` : instr*, `t*` : valtype*, C' : context}: @@ -12692,6 +20755,7 @@ relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, instr*{instr <- `instr*`})) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t^n{t <- `t*`}))) + -- if (n = |`t*`|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, n : n, `catch*` : catch*, `instr*` : instr*, `t_1*` : valtype*, `t_2*` : valtype*, `x*` : idx*}: @@ -12723,20 +20787,26 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:41.1-45.86 - rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*}: + rule seq{s : store, C : context, instr_1 : instr, `instr_2*` : instr*, `t_1*` : valtype*, `x_1*` : idx*, `x_2*` : idx*, `t_3*` : valtype*, `t_2*` : valtype*, `init*` : init*, `t*` : valtype*, var_0 : context?}: `%;%|-%:%`(s, C, [instr_1] ++ instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- (if (C.LOCALS_context[x_1!`%`_uN.0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} - -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`})), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`, x_1 <- `x_1*`} + -- if (|`init*`| = |`t*`|) + -- if (|`init*`| = |`x_1*`|) + -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- `x_1*`} + -- Instrs_ok2: `%;%|-%:%`(s, !(var_0), instr_2*{instr_2 <- `instr_2*`}, `%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- if (var_0 =/= ?()) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- `instr_2*`} + -- wf_context: `%`(!(var_0)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`} ++ x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), x_1*{x_1 <- `x_1*`}, `%`_resulttype(t_2*{t_2 <- `t_2*`}))) -- (wf_localtype: `%`(`%%`_localtype(init, t)))*{init <- `init*`, t <- `t*`} -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- `t*`} -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2*{t_2 <- `t_2*`}), x_2*{x_2 <- `x_2*`}, `%`_resulttype(t_3*{t_3 <- `t_3*`}))) + -- fun_with_locals: `%%%%`(C, x_1*{x_1 <- `x_1*`}, `%%`_localtype(SET_init, t)*{t <- `t*`}, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 rule sub{s : store, C : context, `instr*` : instr*, it' : instrtype, it : instrtype}: @@ -12824,14 +20894,14 @@ relation Tableinst_ok: `%|-%:%`(store, tableinst, tabletype) relation Funcinst_ok: `%|-%:%`(store, funcinst, deftype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, dt : deftype, moduleinst : moduleinst, func : func, C : context, dt' : deftype}: - `%|-%:%`(s, {TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}, dt) + `%|-%:%`(s, {TYPE dt, MODULE moduleinst, CODE $funccode_func(func)}, dt) -- Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) -- Func_ok: `%|-%:%`(C, func, dt') -- Deftype_sub: `%|-%<:%`(C, dt', dt) -- wf_store: `%`(s) -- wf_context: `%`(C) - -- wf_funcinst: `%`({TYPE dt, MODULE moduleinst, CODE (func : func <: funccode)}) + -- wf_funcinst: `%`({TYPE dt, MODULE moduleinst, CODE $funccode_func(func)}) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -12841,6 +20911,7 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) `%|-%:OK`(s, {TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`, zt <- `zt*`} + -- if (|`fv*`| = |`zt*`|) -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -12861,9 +20932,11 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule _{s : store, ta : tagaddr, `val*` : val*, dt : deftype, `t*` : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val*{val <- `val*`}}) - -- if ((dt : deftype <: typeuse) = s.TAGS_store[ta].TYPE_taginst) + -- if ($typeuse_deftype(dt) = s.TAGS_store[ta].TYPE_taginst) + -- if (ta < |s.TAGS_store|) -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- (Val_ok: `%|-%:%`(s, val, t))*{t <- `t*`, val <- `val*`} + -- if (|`t*`| = |`val*`|) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) @@ -12887,51 +20960,69 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) rule `ref.struct`{a : addr, s : store, i : nat, `ft*` : fieldtype*, zt : storagetype}: `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- if (a < |s.STRUCTS_store|) -- if (ft*{ft <- `ft*`}[i] = `%%`_fieldtype(?(), zt)) + -- if (i < |ft*{ft <- `ft*`}|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) + -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule `ref.array`{a : addr, s : store, i : nat, zt : storagetype}: `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- if (a < |s.ARRAYS_store|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule `ref.exn`{a : addr, s : store, i : nat}: - `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, (s.EXNS_store[a].FIELDS_exninst[i] : val <: fieldval)) + `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) + -- if (i < |s.EXNS_store[a].FIELDS_exninst|) + -- if (a < |s.EXNS_store|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:239.1-240.28 rule `ref.extern`{ref : ref, s : store}: - `%>>_%%`(`REF.EXTERN`_fieldval(ref), s, (ref : ref <: fieldval)) + `%>>_%%`(`REF.EXTERN`_fieldval(ref), s, $fieldval_ref(ref)) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.EXTERN`_fieldval(ref)) } ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -def $NotImmutReachable(fieldval : fieldval, store : store, fieldval : fieldval) : bool +relation fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = false + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%`(fv_1, s, fv_2) -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +relation fun_NotImmutReachable: `%%%%`(fieldval, store, fieldval, bool) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = true - -- otherwise + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, false) + -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec + rule fun_NotImmutReachable_case_1{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, true) + -- ~ fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fv_1, s, fv_2) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation NotImmutReachable: `~%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule _{fv_1 : fieldval, s : store, fv_2 : fieldval}: + rule _{fv_1 : fieldval, s : store, fv_2 : fieldval, var_0 : bool}: `~%>>_%%`(fv_1, s, fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) + -- if var_0 -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) @@ -12939,12 +21030,19 @@ relation Store_ok: `|-%:OK`(store) rule _{s : store, `taginst*` : taginst*, `tagtype*` : tagtype*, `globalinst*` : globalinst*, `globaltype*` : globaltype*, `meminst*` : meminst*, `memtype*` : memtype*, `tableinst*` : tableinst*, `tabletype*` : tabletype*, `deftype*` : deftype*, `funcinst*` : funcinst*, `datainst*` : datainst*, `datatype*` : datatype*, `eleminst*` : eleminst*, `elemtype*` : elemtype*, `structinst*` : structinst*, `arrayinst*` : arrayinst*, `exninst*` : exninst*}: `|-%:OK`(s) -- (Taginst_ok: `%|-%:%`(s, taginst, tagtype))*{taginst <- `taginst*`, tagtype <- `tagtype*`} + -- if (|`taginst*`| = |`tagtype*`|) -- (Globalinst_ok: `%|-%:%`(s, globalinst, globaltype))*{globalinst <- `globalinst*`, globaltype <- `globaltype*`} + -- if (|`globalinst*`| = |`globaltype*`|) -- (Meminst_ok: `%|-%:%`(s, meminst, memtype))*{meminst <- `meminst*`, memtype <- `memtype*`} + -- if (|`meminst*`| = |`memtype*`|) -- (Tableinst_ok: `%|-%:%`(s, tableinst, tabletype))*{tableinst <- `tableinst*`, tabletype <- `tabletype*`} + -- if (|`tableinst*`| = |`tabletype*`|) -- (Funcinst_ok: `%|-%:%`(s, funcinst, deftype))*{deftype <- `deftype*`, funcinst <- `funcinst*`} + -- if (|`deftype*`| = |`funcinst*`|) -- (Datainst_ok: `%|-%:%`(s, datainst, datatype))*{datainst <- `datainst*`, datatype <- `datatype*`} + -- if (|`datainst*`| = |`datatype*`|) -- (Eleminst_ok: `%|-%:%`(s, eleminst, elemtype))*{eleminst <- `eleminst*`, elemtype <- `elemtype*`} + -- if (|`eleminst*`| = |`elemtype*`|) -- (Structinst_ok: `%|-%:OK`(s, structinst))*{structinst <- `structinst*`} -- (Arrayinst_ok: `%|-%:OK`(s, arrayinst))*{arrayinst <- `arrayinst*`} -- (Exninst_ok: `%|-%:OK`(s, exninst))*{exninst <- `exninst*`} @@ -13031,6 +21129,8 @@ relation Extend_structinst: `%<=%`(structinst, structinst) `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`, `mut?` <- `mut?*`} + -- if (|`fv*`| = |`fv'*`|) + -- if (|`fv*`| = |`mut?*`|) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -13042,6 +21142,7 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) `%<=%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}, {TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} + -- if (|`fv*`| = |`fv'*`|) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -13059,15 +21160,35 @@ relation Extend_store: `%<=%`(store, store) rule _{s : store, s' : store}: `%<=%`(s, s') -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} + -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} + -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} + -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} + -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} + -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} + -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} + -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} + -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} + -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} + -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} + -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} + -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} + -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} + -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} + -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} + -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} + -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} + -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} + -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} + -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -13159,7 +21280,8 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule `global.get`{C : context, x : idx, t : valtype, mut : mut}: `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- if (C.GLOBALS_context[x!`%`_uN.0] = `%%`_globaltype(?(mut), t)) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) @@ -13202,6 +21324,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(n : n, `instr*` : instr*) @@ -13227,6 +21357,15 @@ relation wf_callframe: `%`(callframe) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $allocX(syntax X, syntax Y, store : store, X : X, Y : Y) : (store, addr) +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax X, syntax Y): `%%%%`(store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax X, syntax Y, store : store, X_0 : X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(store, X_0, Y_0, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocX(syntax X, syntax Y, store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { @@ -13235,9 +21374,22 @@ def $allocXs(syntax X, syntax Y, store : store, X*, Y*) : (store, addr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:33.1-33.57 def $allocXs{syntax X, syntax Y, s : store}(syntax X, syntax Y, s, [], []) = (s, []) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:34.1-36.65 - def $allocXs{syntax X, syntax Y, s : store, X : X, `X'*` : X*, Y : Y, `Y'*` : Y*}(syntax X, syntax Y, s, [X] ++ X'*{X' <- `X'*`}, [Y] ++ Y'*{Y' <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) + def $allocXs{syntax X, syntax Y, s : store, X : X, `X'*` : X*, Y : Y, `Y'*` : Y*}(syntax X, syntax Y, s, [X] ++ X'#1*{X'#1 <- `X'*`}, [Y] ++ Y'#1*{Y'#1 <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) -- let{a : addr, s_1 : store} (s_1, a) = $allocX(syntax X, syntax Y, s, X, Y) - -- let{s_2 : store, `a'*` : addr*} (s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`}) + -- let{s_2 : store, `a'*` : addr*} (s_2, a'#1*{a'#1 <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'#2*{X'#2 <- `X'*`}, Y'#2*{Y'#2 <- `Y'*`}) +} + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax X, syntax Y): `%%%%`(store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax X, syntax Y, store : store, var_0 : X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(store, var_0, var_1, ret_val) + -- wf_store: `%`(store) + -- if (ret_val = $allocXs(syntax X, syntax Y, store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) } ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec @@ -13295,14 +21447,15 @@ grammar BsN(N : N) : sN prod{n : n} `%`_byte(n):Bbyte => `%`_sN(((n : nat <:> int) - ((2 ^ 7) : nat <:> int))) -- if ((((2 ^ 6) <= n) /\ (n < (2 ^ 7))) /\ ((n : nat <:> int) >= (((2 ^ 7) : nat <:> int) - ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:16.5-16.82 - prod{i : sN, n : n} {{`%`_byte(n):Bbyte} {i:BsN((((N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_sN(((((2 ^ 7) * (i!`%`_sN.0 : int <:> nat)) + (((n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat)) : nat <:> int)) + prod{i : sN, n : n} {{`%`_byte(n):Bbyte} {i:BsN((((N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_sN(((((2 ^ 7) * ($proj_sN_0(i).0 : int <:> nat)) + (((n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat)) : nat <:> int)) -- if ((n >= (2 ^ 7)) /\ (N > 7)) } ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BiN(N : N) : iN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{i : sN} i:BsN(N) => `%`_iN($inv_signed_(N, i!`%`_sN.0)) + prod{i : sN, var_0 : nat} i:BsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BfN(N : N) : fN @@ -13352,8 +21505,9 @@ grammar Blist(syntax el, grammar BX : el) : el* ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Bname : name ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{name : name, `b*` : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name - -- if ($utf8(name!`%`_name.0) = b*{b <- `b*`}) + prod{name : name, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Blist(syntax byte, grammar Bbyte) => name + -- if (var_0 = b*{b <- `b*`}) + -- fun_utf8: `%%`($proj_name_0(name).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Btypeidx : typeidx @@ -13472,7 +21626,7 @@ grammar Bheaptype : heaptype prod{ht : heaptype} ht:Babsheaptype => ht ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec prod{x33 : s33} x33:Bs33 => _IDX_heaptype($s33_to_u32(x33)) - -- if (x33!`%`_sN.0 >= (0 : nat <:> int)) + -- if ($proj_sN_0(x33).0 >= (0 : nat <:> int)) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Breftype : reftype @@ -13486,11 +21640,11 @@ grammar Breftype : reftype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bvaltype : valtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{nt : numtype} nt:Bnumtype => (nt : numtype <: valtype) + prod{nt : numtype} nt:Bnumtype => $valtype_numtype(nt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{vt : vectype} vt:Bvectype => (vt : vectype <: valtype) + prod{vt : vectype} vt:Bvectype => $valtype_vectype(vt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{rt : reftype} rt:Breftype => (rt : reftype <: valtype) + prod{rt : reftype} rt:Breftype => $valtype_reftype(rt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bresulttype : resulttype @@ -13514,9 +21668,9 @@ grammar Bpacktype : packtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bstoragetype : storagetype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{t : valtype} t:Bvaltype => (t : valtype <: storagetype) + prod{t : valtype} t:Bvaltype => $storagetype_valtype(t) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{pt : packtype} pt:Bpacktype => (pt : packtype <: storagetype) + prod{pt : packtype} pt:Bpacktype => $storagetype_packtype(pt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bfieldtype : fieldtype @@ -13610,8 +21764,8 @@ grammar Bblocktype : blocktype ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec prod{t : valtype} t:Bvaltype => _RESULT_blocktype(?(t)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{i : s33} i:Bs33 => _IDX_blocktype(`%`_typeidx((i!`%`_sN.0 : int <:> nat))) - -- if (i!`%`_sN.0 >= (0 : nat <:> int)) + prod{i : s33} i:Bs33 => _IDX_blocktype(`%`_typeidx(($proj_sN_0(i).0 : int <:> nat))) + -- if ($proj_sN_0(i).0 >= (0 : nat <:> int)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec grammar Bcatch : catch @@ -13636,7 +21790,7 @@ grammar Bmemarg : memidxop ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec grammar Blaneidx : laneidx ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{l : labelidx} `%`_byte(l!`%`_uN.0):Bbyte => `%`_laneidx(l!`%`_uN.0) + prod{l : labelidx} `%`_byte($proj_uN_0(l).0):Bbyte => `%`_laneidx($proj_uN_0(l).0) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec rec { @@ -14174,7 +22328,7 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:421.5-421.72 prod{`b*` : byte*} {{0xFD} {`%`_u32(12):Bu32} {b:Bbyte^16{b <- `b*`}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, b^16{b <- `b*`})) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:425.5-425.61 - prod{`l*` : labelidx*} {{0xFD} {`%`_u32(13):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx^16{l <- `l*`}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_laneidx(l!`%`_uN.0)^16{l <- `l*`}) + prod{`l*` : labelidx*} {{0xFD} {`%`_u32(13):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx^16{l <- `l*`}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_laneidx($proj_uN_0(l).0)^16{l <- `l*`}) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:426.5-426.49 prod {{0xFD} {`%`_u32(14):Bu32}} => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:427.5-427.58 @@ -14192,33 +22346,33 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:436.5-436.38 prod {{0xFD} {`%`_u32(20):Bu32}} => VSPLAT_instr(`%X%`_shape(F64_lanetype, `%`_dim(2))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:440.5-440.60 - prod{l : labelidx} {{0xFD} {`%`_u32(21):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(21):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:441.5-441.60 - prod{l : labelidx} {{0xFD} {`%`_u32(22):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(22):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:442.5-442.58 - prod{l : labelidx} {{0xFD} {`%`_u32(23):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(23):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:443.5-443.60 - prod{l : labelidx} {{0xFD} {`%`_u32(24):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(24):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:444.5-444.60 - prod{l : labelidx} {{0xFD} {`%`_u32(25):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(25):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:445.5-445.58 - prod{l : labelidx} {{0xFD} {`%`_u32(26):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(26):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:446.5-446.58 - prod{l : labelidx} {{0xFD} {`%`_u32(27):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(27):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:447.5-447.58 - prod{l : labelidx} {{0xFD} {`%`_u32(28):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(28):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:448.5-448.58 - prod{l : labelidx} {{0xFD} {`%`_u32(29):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(29):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:449.5-449.58 - prod{l : labelidx} {{0xFD} {`%`_u32(30):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(30):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:450.5-450.58 - prod{l : labelidx} {{0xFD} {`%`_u32(31):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(31):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:451.5-451.58 - prod{l : labelidx} {{0xFD} {`%`_u32(32):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(32):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:452.5-452.58 - prod{l : labelidx} {{0xFD} {`%`_u32(33):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(33):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:453.5-453.58 - prod{l : labelidx} {{0xFD} {`%`_u32(34):Bu32} {`%`_laneidx(l!`%`_uN.0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%`_laneidx(l!`%`_uN.0)) + prod{l : labelidx} {{0xFD} {`%`_u32(34):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%`_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:457.5-457.41 prod {{0xFD} {`%`_u32(35):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:458.5-458.41 @@ -14840,10 +22994,11 @@ grammar Bversion : () ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bmodule : module ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `typeidx*` : typeidx*, `n?` : n?, `expr*` : expr*, `local**` : local**, var_0 : dataidx*} {Bmagic Bversion {Bcustomsec*{}} {type*{type <- `type*`}:Btypesec} {Bcustomsec*{}} {import*{import <- `import*`}:Bimportsec} {Bcustomsec*{}} {typeidx*{typeidx <- `typeidx*`}:Bfuncsec} {Bcustomsec*{}} {table*{table <- `table*`}:Btablesec} {Bcustomsec*{}} {mem*{mem <- `mem*`}:Bmemsec} {Bcustomsec*{}} {tag*{tag <- `tag*`}:Btagsec} {Bcustomsec*{}} {global*{global <- `global*`}:Bglobalsec} {Bcustomsec*{}} {export*{export <- `export*`}:Bexportsec} {Bcustomsec*{}} {start?{start <- `start?`}:Bstartsec} {Bcustomsec*{}} {elem*{elem <- `elem*`}:Belemsec} {Bcustomsec*{}} {`%`_u32(n)?{n <- `n?`}:Bdatacntsec} {Bcustomsec*{}} {(local*{local <- `local*`}, expr)*{expr <- `expr*`, `local*` <- `local**`}:Bcodesec} {Bcustomsec*{}} {data*{data <- `data*`}:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) -- (if (n = |data*{data <- `data*`}|))?{n <- `n?`} - -- if ((n?{n <- `n?`} =/= ?()) \/ ($dataidx_funcs(func*{func <- `func*`}) = [])) + -- if ((n?{n <- `n?`} =/= ?()) \/ (var_0 = [])) -- (if (func = FUNC_func(typeidx, local*{local <- `local*`}, expr)))*{expr <- `expr*`, func <- `func*`, `local*` <- `local**`, typeidx <- `typeidx*`} + -- fun_dataidx_funcs: `%%`(func*{func <- `func*`}, var_0) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tchar : char @@ -14994,7 +23149,7 @@ grammar Thexnum : nat grammar Tstringchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{c : char} c:Tchar => c - -- if ((((c!`%`_char.0 >= 32) /\ (c!`%`_char.0 =/= 127)) /\ (c =/= `%`_char(34))) /\ (c =/= `%`_char(92))) + -- if (((($proj_char_0(c).0 >= 32) /\ ($proj_char_0(c).0 =/= 127)) /\ (c =/= `%`_char(34))) /\ (c =/= `%`_char(92))) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod "\\t" => `%`_char(9) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -15014,7 +23169,8 @@ grammar Tstringchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tstringelem : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tstringchar => $utf8([c]) + prod{c : char, var_0 : byte*} c:Tstringchar => var_0 + -- fun_utf8: `%%`([c], var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [`%`_byte(((16 * h_1) + h_2))] @@ -15027,8 +23183,9 @@ grammar Tstring : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tname : name ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`c*` : char*, `b*` : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) - -- if (b*{b <- `b*`} = $utf8(c*{c <- `c*`})) + prod{`c*` : char*, `b*` : byte*, var_0 : byte*} b*{b <- `b*`}:Tstring => `%`_name(c*{c <- `c*`}) + -- if (b*{b <- `b*`} = var_0) + -- fun_utf8: `%%`(c*{c <- `c*`}, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tid : name @@ -15108,7 +23265,7 @@ grammar Teof : () grammar Tlinechar : () ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec prod{`` : char, c : char} ``:c:Tchar => (``, ()).1 - -- if ((c!`%`_char.0 =/= 10) /\ (c!`%`_char.0 =/= 13)) + -- if (($proj_char_0(c).0 =/= 10) /\ ($proj_char_0(c).0 =/= 13)) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tnewline : () @@ -15192,7 +23349,8 @@ grammar TiN(N : N) : iN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{n : n} `%`_uN(n):TuN(N) => `%`_iN(n) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{i : sN} i:TsN(N) => `%`_iN($inv_signed_(N, i!`%`_sN.0)) + prod{i : sN, var_0 : nat} i:TsN(N) => `%`_iN(var_0) + -- fun_inv_signed_: `%%%`(N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { @@ -15320,7 +23478,7 @@ grammar Tidx_(ids : name?*) : idx prod{x : idx} x:Tu32 => x ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{x : idx, id : name} id:Tid => x - -- if (ids[x!`%`_uN.0] = ?(id)) + -- if (ids[$proj_uN_0(x).0] = ?(id)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Ttypeidx_(I : I) : typeidx @@ -15375,7 +23533,7 @@ grammar Tlabelidx_(I : I) : labelidx ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tfieldidx__(I : I, x : idx) : fieldidx ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : idx} ``:Tidx_(I.FIELDS_I[x!`%`_uN.0]) => `` + prod{`` : idx} ``:Tidx_(I.FIELDS_I[$proj_uN_0(x).0]) => `` ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Texternidx_(I : I) : externidx @@ -15453,11 +23611,11 @@ grammar Treftype_(I : I) : reftype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tvaltype_(I : I) : valtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{nt : numtype} nt:Tnumtype => (nt : numtype <: valtype) + prod{nt : numtype} nt:Tnumtype => $valtype_numtype(nt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{vt : vectype} vt:Tvectype => (vt : vectype <: valtype) + prod{vt : vectype} vt:Tvectype => $valtype_vectype(vt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{rt : reftype} rt:Treftype_(I) => (rt : reftype <: valtype) + prod{rt : reftype} rt:Treftype_(I) => $valtype_reftype(rt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tpacktype : packtype @@ -15469,9 +23627,9 @@ grammar Tpacktype : packtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tstoragetype_(I : I) : storagetype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} t:Tvaltype_(I) => (t : valtype <: storagetype) + prod{t : valtype} t:Tvaltype_(I) => $storagetype_valtype(t) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{pt : packtype} pt:Tpacktype => (pt : packtype <: storagetype) + prod{pt : packtype} pt:Tpacktype => $storagetype_packtype(pt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tfieldtype_(I : I) : fieldtype @@ -15522,7 +23680,8 @@ grammar Ttypedef_(I : I) : (subtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Trectype_(I : I) : (rectype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{`st*` : subtype*, `I'*` : I*} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), $concat_idctxt(I'*{I' <- `I'*`})) + prod{`st*` : subtype*, `I'*` : I*, var_0 : idctxt} {{"("} {"rec"} {(st, I')*{I' <- `I'*`, st <- `st*`}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(I))} {")"}} => (REC_rectype(`%`_list(st*{st <- `st*`})), var_0) + -- fun_concat_idctxt: `%%`(I'*{I' <- `I'*`}, var_0) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Taddrtype : addrtype @@ -15542,12 +23701,12 @@ grammar Tlimits : limits grammar Ttypeuse_(I : I) : (typeidx, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec prod{x : idx, I' : I, `st*` : subtype*, i : n, `t_1*` : valtype*, `t_2*` : valtype*} {{"("} {"type"} {x:Ttypeidx_(I)} {")"}} => (x, I') - -- if (I.TYPEDEFS_I[x!`%`_uN.0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) + -- if (I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) -- if (st*{st <- `st*`}[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))^|t_1*{t_1 <- `t_1*`}|{}, LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec prod{x : idx, I' : I, `id?*` : char?*, `t_1*` : valtype*, `t_2*` : valtype*, `st*` : subtype*, i : n} {{"("} {"type"} {x:Ttypeidx_(I)} {")"} {(t_1, ?(`%`_name(lift(id?{id <- `id?`}))))*{`id?` <- `id?*`, t_1 <- `t_1*`}:Tparam_(I)*{}} {t_2*{t_2 <- `t_2*`}:Tresult_(I)*{}}} => (x, I') - -- if (I.TYPEDEFS_I[x!`%`_uN.0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) + -- if (I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(`%`_list(st*{st <- `st*`})), i))) -- if (st*{st <- `st*`}[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`})))) -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name(lift(id?{id <- `id?`})))*{`id?` <- `id?*`}, LABELS [], FIELDS [], TYPEDEFS []}) -- Idctxt_ok: `|-%:OK`(I') @@ -15595,8 +23754,8 @@ grammar Tlabel_(I : I) : (name?, I) prod{id : name} id:Tid => (?(id), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [?(id)], FIELDS [], TYPEDEFS []} +++ I) -- if ~ (?(id) <- I.LABELS_I) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{id : name, x : idx} id:Tid => (?(id), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [?(id)], FIELDS [], TYPEDEFS []} +++ I[LABELS_I[x!`%`_uN.0] = ?()]) - -- if (?(id) = I.LABELS_I[x!`%`_uN.0]) + prod{id : name, x : idx} id:Tid => (?(id), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [?(id)], FIELDS [], TYPEDEFS []} +++ I[LABELS_I[$proj_uN_0(x).0] = ?()]) + -- if (?(id) = I.LABELS_I[$proj_uN_0(x).0]) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tblocktype_(I : I) : blocktype @@ -15604,7 +23763,7 @@ grammar Tblocktype_(I : I) : blocktype prod{`t?` : valtype?} t?{t <- `t?`}:Tresult_(I)?{} => _RESULT_blocktype(t?{t <- `t?`}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(I : I) : catch @@ -15675,7 +23834,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -15684,7 +23843,7 @@ grammar Tplaininstr_(I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(I)} {(y, I'):Ttypeuse_(I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -16713,9 +24872,10 @@ grammar Tlocal_(I : I) : (local*, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tfunc_(I : I) : (func, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -- if (I' = I +++ I_1 +++ $concat_idctxt(I_2*{I_2 <- `I_2*`})) + prod{x : idx, `loc**` : local**, e : expr, `id?` : char?, I_1 : I, `I_2*` : I*, I' : I, var_0 : I} {{"("} {"func"} {?(`%`_name(lift(id?{id <- `id?`}))):Tid?{}} {(x, I_1):Ttypeuse_(I)} {(loc*{loc <- `loc*`}, I_2):Tlocal_(I)*{I_2 <- `I_2*`, `loc*` <- `loc**`}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc*{loc <- `loc*`}*{`loc*` <- `loc**`}), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id?{id <- `id?`})))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = I +++ I_1 +++ var_0) -- Idctxt_ok: `|-%:OK`(I') + -- fun_concat_idctxt: `%%`(I_2*{I_2 <- `I_2*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdatastring : byte* @@ -16851,46 +25011,59 @@ grammar Telemtable_(I : I) : () ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecl_(I : I) : (decl, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (type, idctxt)} ``:Ttype_(I) => (`` : (type, idctxt) <: (decl, idctxt)) + prod{`` : (type, idctxt)} ``:Ttype_(I) => ($decl_type(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (import, idctxt)} ``:Timport_(I) => (`` : (import, idctxt) <: (decl, idctxt)) + prod{`` : (import, idctxt)} ``:Timport_(I) => ($decl_import(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (tag, idctxt)} ``:Ttag_(I) => (`` : (tag, idctxt) <: (decl, idctxt)) + prod{`` : (tag, idctxt)} ``:Ttag_(I) => ($decl_tag(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (global, idctxt)} ``:Tglobal_(I) => (`` : (global, idctxt) <: (decl, idctxt)) + prod{`` : (global, idctxt)} ``:Tglobal_(I) => ($decl_global(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (mem, idctxt)} ``:Tmem_(I) => (`` : (mem, idctxt) <: (decl, idctxt)) + prod{`` : (mem, idctxt)} ``:Tmem_(I) => ($decl_mem(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (table, idctxt)} ``:Ttable_(I) => (`` : (table, idctxt) <: (decl, idctxt)) + prod{`` : (table, idctxt)} ``:Ttable_(I) => ($decl_table(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (func, idctxt)} ``:Tfunc_(I) => (`` : (func, idctxt) <: (decl, idctxt)) + prod{`` : (func, idctxt)} ``:Tfunc_(I) => ($decl_func(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (data, idctxt)} ``:Tdata_(I) => (`` : (data, idctxt) <: (decl, idctxt)) + prod{`` : (data, idctxt)} ``:Tdata_(I) => ($decl_data(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (elem, idctxt)} ``:Telem_(I) => (`` : (elem, idctxt) <: (decl, idctxt)) + prod{`` : (elem, idctxt)} ``:Telem_(I) => ($decl_elem(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (start, idctxt)} ``:Tstart_(I) => (`` : (start, idctxt) <: (decl, idctxt)) + prod{`` : (start, idctxt)} ``:Tstart_(I) => ($decl_start(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`` : (export, idctxt)} ``:Texport_(I) => (`` : (export, idctxt) <: (decl, idctxt)) + prod{`` : (export, idctxt)} ``:Texport_(I) => ($decl_export(``.0), ``.1) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tmodule : module ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) - -- if (I' = $concat_idctxt(I*{I <- `I*`})) + prod{`type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `I*` : I*, `decl*` : decl*, I' : I, var_12 : bool, var_11 : export*, var_10 : start*, var_9 : elem*, var_8 : data*, var_7 : func*, var_6 : table*, var_5 : mem*, var_4 : global*, var_3 : tag*, var_2 : import*, var_1 : type*, var_0 : idctxt} {{"("} {"module"} {Tid?{}} {(decl, I)*{I <- `I*`, decl <- `decl*`}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type*{type <- `type*`}), `%`_list(import*{import <- `import*`}), `%`_list(tag*{tag <- `tag*`}), `%`_list(global*{global <- `global*`}), `%`_list(mem*{mem <- `mem*`}), `%`_list(table*{table <- `table*`}), `%`_list(func*{func <- `func*`}), `%`_list(data*{data <- `data*`}), `%`_list(elem*{elem <- `elem*`}), start?{start <- `start?`}, `%`_list(export*{export <- `export*`})) + -- if (I' = var_0) -- Idctxt_ok: `|-%:OK`(I') - -- if (type*{type <- `type*`} = $typesd(decl*{decl <- `decl*`})) - -- if (import*{import <- `import*`} = $importsd(decl*{decl <- `decl*`})) - -- if (tag*{tag <- `tag*`} = $tagsd(decl*{decl <- `decl*`})) - -- if (global*{global <- `global*`} = $globalsd(decl*{decl <- `decl*`})) - -- if (mem*{mem <- `mem*`} = $memsd(decl*{decl <- `decl*`})) - -- if (table*{table <- `table*`} = $tablesd(decl*{decl <- `decl*`})) - -- if (func*{func <- `func*`} = $funcsd(decl*{decl <- `decl*`})) - -- if (data*{data <- `data*`} = $datasd(decl*{decl <- `decl*`})) - -- if (elem*{elem <- `elem*`} = $elemsd(decl*{decl <- `decl*`})) - -- if (lift(start?{start <- `start?`}) = $startsd(decl*{decl <- `decl*`})) - -- if (export*{export <- `export*`} = $exportsd(decl*{decl <- `decl*`})) - -- if $ordered(decl*{decl <- `decl*`}) + -- if (type*{type <- `type*`} = var_1) + -- if (import*{import <- `import*`} = var_2) + -- if (tag*{tag <- `tag*`} = var_3) + -- if (global*{global <- `global*`} = var_4) + -- if (mem*{mem <- `mem*`} = var_5) + -- if (table*{table <- `table*`} = var_6) + -- if (func*{func <- `func*`} = var_7) + -- if (data*{data <- `data*`} = var_8) + -- if (elem*{elem <- `elem*`} = var_9) + -- if (lift(start?{start <- `start?`}) = var_10) + -- if (export*{export <- `export*`} = var_11) + -- if var_12 + -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_12) + -- fun_exportsd: `%%`(decl*{decl <- `decl*`}, var_11) + -- fun_startsd: `%%`(decl*{decl <- `decl*`}, var_10) + -- fun_elemsd: `%%`(decl*{decl <- `decl*`}, var_9) + -- fun_datasd: `%%`(decl*{decl <- `decl*`}, var_8) + -- fun_funcsd: `%%`(decl*{decl <- `decl*`}, var_7) + -- fun_tablesd: `%%`(decl*{decl <- `decl*`}, var_6) + -- fun_memsd: `%%`(decl*{decl <- `decl*`}, var_5) + -- fun_globalsd: `%%`(decl*{decl <- `decl*`}, var_4) + -- fun_tagsd: `%%`(decl*{decl <- `decl*`}, var_3) + -- fun_importsd: `%%`(decl*{decl <- `decl*`}, var_2) + -- fun_typesd: `%%`(decl*{decl <- `decl*`}, var_1) + -- fun_concat_idctxt: `%%`(I*{I <- `I*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecldots_(I : I) : (decl, idctxt)* diff --git a/spectec/test-middlend/specification.exp/13-improve-ids.il b/spectec/test-middlend/specification.exp/15-improve-ids.il similarity index 51% rename from spectec/test-middlend/specification.exp/13-improve-ids.il rename to spectec/test-middlend/specification.exp/15-improve-ids.il index d1722b8b55..b380d5b2da 100644 --- a/spectec/test-middlend/specification.exp/13-improve-ids.il +++ b/spectec/test-middlend/specification.exp/15-improve-ids.il @@ -22,23 +22,31 @@ def $min(nat : nat, nat_0 : nat) : nat ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.1-9.56 -def $sum(var_0 : nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:10.1-10.18 - def $sum([]) = 0 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:11.1-11.35 - def $sum{v_n : nat, n'_lst : n*}([v_n] ++ n'_lst) = (v_n + $sum(n'_lst)) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 +relation fun_sum: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_0: + `%%`([], 0) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:9.6-9.10 + rule fun_sum_case_1{v_n : nat, n'_lst : n*, var_0 : nat}: + `%%`([v_n] ++ n'_lst, (v_n + var_0)) + -- fun_sum: `%%`(n'_lst, var_0) } ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec rec { -;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.1-13.57 -def $prod(var_0 : nat*) : nat - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:14.1-14.19 - def $prod([]) = 1 - ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:15.1-15.37 - def $prod{v_n : nat, n'_lst : n*}([v_n] ++ n'_lst) = (v_n * $prod(n'_lst)) +;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 +relation fun_prod: `%%`(nat*, nat) + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_0: + `%%`([], 1) + + ;; ../../../../specification/wasm-3.0/0.2-aux.num.spectec:13.6-13.11 + rule fun_prod_case_1{v_n : nat, n'_lst : n*, var_0 : nat}: + `%%`([v_n] ++ n'_lst, (v_n * var_0)) + -- fun_prod: `%%`(n'_lst, var_0) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -70,6 +78,8 @@ def $concatn_(syntax X, var_0 : X**, nat : nat) : X* def $concatn_{syntax X, v_n : nat}(syntax X, [], v_n) = [] ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec:20.1-20.73 def $concatn_{syntax X, v_n : nat, w_lst : X*, w'_lst_lst : X**}(syntax X, [w_lst] ++ w'_lst_lst, v_n) = w_lst ++ $concatn_(syntax X, w'_lst_lst, v_n) + -- if (v_n = |w_lst|) + -- (if (v_n = |w'_lst_2|))*{w'_lst_2 <- w'_lst_lst} } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -156,61 +166,61 @@ def $ND : bool ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax bit = - | `%`(i : nat) + | mk_bit(i : nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_bit: `%`(bit) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule bit_case_0{i : nat}: - `%`(`%`_bit(i)) + `%`(mk_bit_bit(i)) -- if ((i = 0) \/ (i = 1)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax byte = - | `%`(i : nat) + | mk_byte(i : nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_byte_0(x : byte) : (nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_byte_0{v_num_0 : nat}(`%`_byte(v_num_0)) = (v_num_0) + def $proj_byte_0{v_num_0 : nat}(mk_byte_byte(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_byte: `%`(byte) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule byte_case_0{i : nat}: - `%`(`%`_byte(i)) + `%`(mk_byte_byte(i)) -- if ((i >= 0) /\ (i <= 255)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax uN = - | `%`(i : nat) + | mk_uN(i : nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_uN_0(x : uN) : (nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_uN_0{v_num_0 : nat}(`%`_uN(v_num_0)) = (v_num_0) + def $proj_uN_0{v_num_0 : nat}(mk_uN_uN(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_uN: `%%`(N, uN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule uN_case_0{v_N : N, i : nat}: - `%%`(v_N, `%`_uN(i)) + `%%`(v_N, mk_uN_uN(i)) -- if ((i >= 0) /\ (i <= ((((2 ^ v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax sN = - | `%`(i : int) + | mk_sN(i : int) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_sN_0(x : sN) : (int) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_sN_0{v_num_0 : int}(`%`_sN(v_num_0)) = (v_num_0) + def $proj_sN_0{v_num_0 : int}(mk_sN_sN(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_sN: `%%`(N, sN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule sN_case_0{v_N : N, i : int}: - `%%`(v_N, `%`_sN(i)) + `%%`(v_N, mk_sN_sN(i)) -- if ((((i >= - ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) /\ (i <= - (1 : nat <:> int))) \/ (i = (0 : nat <:> int))) \/ ((i >= + (1 : nat <:> int)) /\ (i <= (+ ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -329,19 +339,40 @@ syntax f64 = fN def $fzero(v_N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fzero{v_N : nat}(v_N) = POS_fN(SUBNORM_fNmag(0)) - -- wf_fN: `%%`(v_N, POS_fN(SUBNORM_fNmag(0))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fzero_is_wf: `%%`(v_N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fzero_is_wf_0{v_N : N, ret_val : fN}: + `%%`(v_N, ret_val) + -- if (ret_val = $fzero(v_N)) + -- wf_fN: `%%`(v_N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat(v_N : N, nat : nat) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fnat{v_N : nat, v_n : nat}(v_N, v_n) = POS_fN(NORM_fNmag(v_n, (0 : nat <:> int))) - -- wf_fN: `%%`(v_N, POS_fN(NORM_fNmag(v_n, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fnat_is_wf: `%%%`(v_N : N, nat : nat, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fnat_is_wf_0{v_N : N, nat : nat, ret_val : fN}: + `%%%`(v_N, nat, ret_val) + -- if (ret_val = $fnat(v_N, nat)) + -- wf_fN: `%%`(v_N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone(v_N : N) : fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $fone{v_N : nat}(v_N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) - -- wf_fN: `%%`(v_N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fone_is_wf: `%%`(v_N : N, ret_val : fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fone_is_wf_0{v_N : N, ret_val : fN}: + `%%`(v_N, ret_val) + -- if (ret_val = $fone(v_N)) + -- wf_fN: `%%`(v_N, ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $canon_(v_N : N) : nat @@ -356,87 +387,111 @@ syntax v128 = vN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax list{syntax X}(syntax X) = - | `%`(X_lst : X*) + | mk_list(X_lst : X*) -- if (|X_lst| < (2 ^ 32)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_list_0(syntax X, x : list(syntax X)) : (X*) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_list_0{syntax X, v_X_list_0 : X*}(syntax X, `%`_list(v_X_list_0)) = (v_X_list_0) + def $proj_list_0{syntax X, v_X_list_0 : X*}(syntax X, mk_list_list(v_X_list_0)) = (v_X_list_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax char = - | `%`(i : nat) + | mk_char(i : nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_char_0(x : char) : (nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_char_0{v_num_0 : nat}(`%`_char(v_num_0)) = (v_num_0) + def $proj_char_0{v_num_0 : nat}(mk_char_char(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_char: `%`(char) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule char_case_0{i : nat}: - `%`(`%`_char(i)) + `%`(mk_char_char(i)) -- if (((i >= 0) /\ (i <= 55295)) \/ ((i >= 57344) /\ (i <= 1114111))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec -def $cont(v_byte : byte) : nat +relation fun_cont: `%%`(byte, nat) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - def $cont{b : byte}(b) = ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat) + rule fun_cont_case_0{b : byte}: + `%%`(b, ((($proj_byte_0(b).0 : nat <:> int) - (128 : nat <:> int)) : int <:> nat)) -- if ((128 < $proj_byte_0(b).0) /\ ($proj_byte_0(b).0 < 192)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.1-91.25 -def $utf8(var_0 : char*) : byte* - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:52.1-52.44 - def $utf8{ch_lst : char*}(ch_lst) = $concat_(syntax byte, $utf8([ch])*{ch <- ch_lst}) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:53.1-55.15 - def $utf8{ch : char}([ch]) = [b] +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation fun_utf8: `%%`(char*, byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_0{ch_lst : char*, var_0_lst : byte**}: + `%%`(ch_lst, $concat_(syntax byte, var_0_lst)) + -- (fun_utf8: `%%`([ch], var_0))*{var_0 <- var_0_lst, ch <- ch_lst} + -- if (|var_0_lst| = |ch_lst|) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_1{ch : char}: + `%%`([ch], [b]) -- if ($proj_char_0(ch).0 < 128) - -- let{b : byte} b = `%`_byte($proj_char_0(ch).0) - -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:56.1-58.46 - def $utf8{ch : char, b_1 : byte, b_2 : byte}([ch]) = [b_1 b_2] + -- let{b : byte} b = mk_byte_byte($proj_char_0(ch).0) + -- wf_byte: `%`(mk_byte_byte($proj_char_0(ch).0)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_2{ch : char, b_1 : byte, b_2 : byte, var_0 : nat}: + `%%`([ch], [b_1 b_2]) -- if ((128 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 2048)) - -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + $cont(b_2))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:59.1-61.64 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte}([ch]) = [b_1 b_2 b_3] + -- if ($proj_char_0(ch).0 = (((2 ^ 6) * ((($proj_byte_0(b_1).0 : nat <:> int) - (192 : nat <:> int)) : int <:> nat)) + var_0)) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_3{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3]) -- if (((2048 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 55296)) \/ ((57344 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 65536))) - -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * $cont(b_2))) + $cont(b_3))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:62.1-64.82 - def $utf8{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte}([ch]) = [b_1 b_2 b_3 b_4] + -- if ($proj_char_0(ch).0 = ((((2 ^ 12) * ((($proj_byte_0(b_1).0 : nat <:> int) - (224 : nat <:> int)) : int <:> nat)) + ((2 ^ 6) * var_0)) + var_1)) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_4{ch : char, b_1 : byte, b_2 : byte, b_3 : byte, b_4 : byte, var_2 : nat, var_1 : nat, var_0 : nat}: + `%%`([ch], [b_1 b_2 b_3 b_4]) -- if ((65536 <= $proj_char_0(ch).0) /\ ($proj_char_0(ch).0 < 69632)) - -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * $cont(b_2))) + ((2 ^ 6) * $cont(b_3))) + $cont(b_4))) - -- wf_byte: `%`(b_1) - -- wf_byte: `%`(b_2) - -- wf_byte: `%`(b_3) - -- wf_byte: `%`(b_4) + -- if ($proj_char_0(ch).0 = (((((2 ^ 18) * ((($proj_byte_0(b_1).0 : nat <:> int) - (240 : nat <:> int)) : int <:> nat)) + ((2 ^ 12) * var_0)) + ((2 ^ 6) * var_1)) + var_2)) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) +} + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 +relation utf8_is_wf: `%%`(var_0 : char*, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule utf8_is_wf_0{var_0 : char*, ret_val : byte*, var_1 : byte*}: + `%%`(var_0, ret_val) + -- (wf_char: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + -- fun_utf8: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax name = - | `%`(char_lst : char*) + | mk_name(char_lst : char*) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $proj_name_0(x : name) : (char*) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $proj_name_0{v_char_list_0 : char*}(`%`_name(v_char_list_0)) = (v_char_list_0) + def $proj_name_0{v_char_list_0 : char*}(mk_name_name(v_char_list_0)) = (v_char_list_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec relation wf_name: `%`(name) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule name_case_0{char_lst : char*}: - `%`(`%`_name(char_lst)) + rule name_case_0{char_lst : char*, var_0 : byte*}: + `%`(mk_name_name(char_lst)) -- (wf_char: `%`(v_char))*{v_char <- char_lst} - -- if (|$utf8(char_lst)| < (2 ^ 32)) + -- if (|var_0| < (2 ^ 32)) + -- fun_utf8: `%%`(char_lst, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax idx = u32 @@ -515,66 +570,101 @@ relation wf_externidx: `%`(externidx) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.1-129.86 -def $funcsxx(var_0 : externidx*) : typeidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:135.1-135.24 - def $funcsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:136.1-136.45 - def $funcsxx{x : uN, xx_lst : externidx*}([FUNC_externidx(x)] ++ xx_lst) = [x] ++ $funcsxx(xx_lst) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:137.1-137.58 - def $funcsxx{v_externidx : externidx, xx_lst : externidx*}([v_externidx] ++ xx_lst) = $funcsxx(xx_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 +relation fun_funcsxx: `%%`(externidx*, typeidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_1{x : uN, xx_lst : externidx*, var_0 : typeidx*}: + `%%`([FUNC_externidx(x)] ++ xx_lst, [x] ++ var_0) + -- fun_funcsxx: `%%`(xx_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:129.6-129.14 + rule fun_funcsxx_case_2{v_externidx : externidx, xx_lst : externidx*, var_0 : typeidx*}: + `%%`([v_externidx] ++ xx_lst, var_0) + -- fun_funcsxx: `%%`(xx_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.1-130.88 -def $globalsxx(var_0 : externidx*) : globalidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:139.1-139.26 - def $globalsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:140.1-140.51 - def $globalsxx{x : uN, xx_lst : externidx*}([GLOBAL_externidx(x)] ++ xx_lst) = [x] ++ $globalsxx(xx_lst) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:141.1-141.62 - def $globalsxx{v_externidx : externidx, xx_lst : externidx*}([v_externidx] ++ xx_lst) = $globalsxx(xx_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 +relation fun_globalsxx: `%%`(externidx*, globalidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_1{x : uN, xx_lst : externidx*, var_0 : globalidx*}: + `%%`([GLOBAL_externidx(x)] ++ xx_lst, [x] ++ var_0) + -- fun_globalsxx: `%%`(xx_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:130.6-130.16 + rule fun_globalsxx_case_2{v_externidx : externidx, xx_lst : externidx*, var_0 : globalidx*}: + `%%`([v_externidx] ++ xx_lst, var_0) + -- fun_globalsxx: `%%`(xx_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.1-131.87 -def $tablesxx(var_0 : externidx*) : tableidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:143.1-143.25 - def $tablesxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:144.1-144.48 - def $tablesxx{x : uN, xx_lst : externidx*}([TABLE_externidx(x)] ++ xx_lst) = [x] ++ $tablesxx(xx_lst) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:145.1-145.60 - def $tablesxx{v_externidx : externidx, xx_lst : externidx*}([v_externidx] ++ xx_lst) = $tablesxx(xx_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 +relation fun_tablesxx: `%%`(externidx*, tableidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_1{x : uN, xx_lst : externidx*, var_0 : tableidx*}: + `%%`([TABLE_externidx(x)] ++ xx_lst, [x] ++ var_0) + -- fun_tablesxx: `%%`(xx_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:131.6-131.15 + rule fun_tablesxx_case_2{v_externidx : externidx, xx_lst : externidx*, var_0 : tableidx*}: + `%%`([v_externidx] ++ xx_lst, var_0) + -- fun_tablesxx: `%%`(xx_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.1-132.85 -def $memsxx(var_0 : externidx*) : memidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:147.1-147.23 - def $memsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:148.1-148.42 - def $memsxx{x : uN, xx_lst : externidx*}([MEM_externidx(x)] ++ xx_lst) = [x] ++ $memsxx(xx_lst) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:149.1-149.56 - def $memsxx{v_externidx : externidx, xx_lst : externidx*}([v_externidx] ++ xx_lst) = $memsxx(xx_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 +relation fun_memsxx: `%%`(externidx*, memidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_1{x : uN, xx_lst : externidx*, var_0 : memidx*}: + `%%`([MEM_externidx(x)] ++ xx_lst, [x] ++ var_0) + -- fun_memsxx: `%%`(xx_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:132.6-132.13 + rule fun_memsxx_case_2{v_externidx : externidx, xx_lst : externidx*, var_0 : memidx*}: + `%%`([v_externidx] ++ xx_lst, var_0) + -- fun_memsxx: `%%`(xx_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.1-133.85 -def $tagsxx(var_0 : externidx*) : tagidx* - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:151.1-151.23 - def $tagsxx([]) = [] - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:152.1-152.42 - def $tagsxx{x : uN, xx_lst : externidx*}([TAG_externidx(x)] ++ xx_lst) = [x] ++ $tagsxx(xx_lst) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:153.1-153.56 - def $tagsxx{v_externidx : externidx, xx_lst : externidx*}([v_externidx] ++ xx_lst) = $tagsxx(xx_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 +relation fun_tagsxx: `%%`(externidx*, tagidx*) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_1{x : uN, xx_lst : externidx*, var_0 : tagidx*}: + `%%`([TAG_externidx(x)] ++ xx_lst, [x] ++ var_0) + -- fun_tagsxx: `%%`(xx_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:133.6-133.13 + rule fun_tagsxx_case_2{v_externidx : externidx, xx_lst : externidx*, var_0 : tagidx*}: + `%%`([v_externidx] ++ xx_lst, var_0) + -- fun_tagsxx: `%%`(xx_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -612,81 +702,186 @@ relation wf_free: `%`(free) def $free_opt(var_0 : free?) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt(?()) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_opt{v_free : free}(?(v_free)) = v_free +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_opt_is_wf: `%%`(var_0 : free?, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_opt_is_wf_0{var_0 : free?, ret_val : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))?{var_0 <- var_0} + -- if (ret_val = $free_opt(var_0)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation fun_free_list: `%%`(free*, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_0: + `%%`([], {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule fun_free_list_case_1{v_free : free, free'_lst : free*, var_0 : free}: + `%%`([v_free] ++ free'_lst, v_free +++ var_0) + -- fun_free_list: `%%`(free'_lst, var_0) +} + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rec { -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.1-173.29 -def $free_list(var_0 : free*) : free - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:178.1-178.25 - def $free_list([]) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:179.1-179.57 - def $free_list{v_free : free, free'_lst : free*}([v_free] ++ free'_lst) = v_free +++ $free_list(free'_lst) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 +relation free_list_is_wf: `%%`(var_0 : free*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:173.6-173.16 + rule free_list_is_wf_0{var_0 : free*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_free: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_list: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx(v_typeidx : typeidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_typeidx{v_typeidx : uN}(v_typeidx) = {TYPES [v_typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [v_typeidx], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_typeidx_is_wf: `%%`(v_typeidx : typeidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_typeidx_is_wf_0{v_typeidx : typeidx, ret_val : free}: + `%%`(v_typeidx, ret_val) + -- wf_uN: `%%`(32, v_typeidx) + -- if (ret_val = $free_typeidx(v_typeidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx(v_funcidx : funcidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_funcidx{v_funcidx : uN}(v_funcidx) = {TYPES [], FUNCS [v_funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [v_funcidx], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_funcidx_is_wf: `%%`(v_funcidx : funcidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_funcidx_is_wf_0{v_funcidx : funcidx, ret_val : free}: + `%%`(v_funcidx, ret_val) + -- wf_uN: `%%`(32, v_funcidx) + -- if (ret_val = $free_funcidx(v_funcidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx(v_globalidx : globalidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_globalidx{v_globalidx : uN}(v_globalidx) = {TYPES [], FUNCS [], GLOBALS [v_globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [v_globalidx], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_globalidx_is_wf: `%%`(v_globalidx : globalidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_globalidx_is_wf_0{v_globalidx : globalidx, ret_val : free}: + `%%`(v_globalidx, ret_val) + -- wf_uN: `%%`(32, v_globalidx) + -- if (ret_val = $free_globalidx(v_globalidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx(v_tableidx : tableidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tableidx{v_tableidx : uN}(v_tableidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [v_tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [v_tableidx], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tableidx_is_wf: `%%`(v_tableidx : tableidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tableidx_is_wf_0{v_tableidx : tableidx, ret_val : free}: + `%%`(v_tableidx, ret_val) + -- wf_uN: `%%`(32, v_tableidx) + -- if (ret_val = $free_tableidx(v_tableidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx(v_memidx : memidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_memidx{v_memidx : uN}(v_memidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [v_memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [v_memidx], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_memidx_is_wf: `%%`(v_memidx : memidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_memidx_is_wf_0{v_memidx : memidx, ret_val : free}: + `%%`(v_memidx, ret_val) + -- wf_uN: `%%`(32, v_memidx) + -- if (ret_val = $free_memidx(v_memidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx(v_elemidx : elemidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_elemidx{v_elemidx : uN}(v_elemidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [v_elemidx], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [v_elemidx], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_elemidx_is_wf: `%%`(v_elemidx : elemidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_elemidx_is_wf_0{v_elemidx : elemidx, ret_val : free}: + `%%`(v_elemidx, ret_val) + -- wf_uN: `%%`(32, v_elemidx) + -- if (ret_val = $free_elemidx(v_elemidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx(v_dataidx : dataidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_dataidx{v_dataidx : uN}(v_dataidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [v_dataidx], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [v_dataidx], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_dataidx_is_wf: `%%`(v_dataidx : dataidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_dataidx_is_wf_0{v_dataidx : dataidx, ret_val : free}: + `%%`(v_dataidx, ret_val) + -- wf_uN: `%%`(32, v_dataidx) + -- if (ret_val = $free_dataidx(v_dataidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx(v_localidx : localidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_localidx{v_localidx : uN}(v_localidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [v_localidx], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [v_localidx], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_localidx_is_wf: `%%`(v_localidx : localidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_localidx_is_wf_0{v_localidx : localidx, ret_val : free}: + `%%`(v_localidx, ret_val) + -- wf_uN: `%%`(32, v_localidx) + -- if (ret_val = $free_localidx(v_localidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx(v_labelidx : labelidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_labelidx{v_labelidx : uN}(v_labelidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [v_labelidx], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [v_labelidx], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_labelidx_is_wf: `%%`(v_labelidx : labelidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_labelidx_is_wf_0{v_labelidx : labelidx, ret_val : free}: + `%%`(v_labelidx, ret_val) + -- wf_uN: `%%`(32, v_labelidx) + -- if (ret_val = $free_labelidx(v_labelidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx(v_tagidx : tagidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_tagidx{v_tagidx : uN}(v_tagidx) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [v_tagidx]} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS [v_tagidx]}) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_tagidx_is_wf: `%%`(v_tagidx : tagidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_tagidx_is_wf_0{v_tagidx : tagidx, ret_val : free}: + `%%`(v_tagidx, ret_val) + -- wf_uN: `%%`(32, v_tagidx) + -- if (ret_val = $free_tagidx(v_tagidx)) + -- wf_free: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx(v_externidx : externidx) : free @@ -701,6 +896,15 @@ def $free_externidx(v_externidx : externidx) : free ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec def $free_externidx{v_tagidx : uN}(TAG_externidx(v_tagidx)) = $free_tagidx(v_tagidx) +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation free_externidx_is_wf: `%%`(v_externidx : externidx, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule free_externidx_is_wf_0{v_externidx : externidx, ret_val : free}: + `%%`(v_externidx, ret_val) + -- wf_externidx: `%`(v_externidx) + -- if (ret_val = $free_externidx(v_externidx)) + -- wf_free: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = | NULL @@ -815,7 +1019,7 @@ syntax storagetype = ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.1-112.61 syntax fieldtype = - | `%%`(mut_opt : mut?, v_storagetype : storagetype) + | mk_fieldtype(mut_opt : mut?, v_storagetype : storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.1-117.34 syntax comptype = @@ -1052,7 +1256,7 @@ relation wf_storagetype: `%`(storagetype) relation wf_fieldtype: `%`(fieldtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:112.8-112.17 rule fieldtype_case_0{mut_opt : mut?, v_storagetype : storagetype}: - `%`(`%%`_fieldtype(mut_opt, v_storagetype)) + `%`(mk_fieldtype_fieldtype(mut_opt, v_storagetype)) -- wf_storagetype: `%`(v_storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:114.8-114.16 @@ -1149,77 +1353,168 @@ syntax Cnn = | F64 | V128 +def $storagetype_Cnn(var_0 : Cnn) : storagetype + def $storagetype_Cnn(I32_Cnn) = I32_storagetype + def $storagetype_Cnn(I64_Cnn) = I64_storagetype + def $storagetype_Cnn(F32_Cnn) = F32_storagetype + def $storagetype_Cnn(F64_Cnn) = F64_storagetype + def $storagetype_Cnn(V128_Cnn) = V128_storagetype + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ANYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ANYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ANYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EQREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EQREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EQREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation I31REF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule I31REF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $I31REF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation STRUCTREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule STRUCTREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $STRUCTREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation ARRAYREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule ARRAYREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $ARRAYREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation FUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule FUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $FUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation EXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule EXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $EXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLFUNCREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLFUNCREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLFUNCREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) - -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation NULLEXTERNREF_is_wf: `%`(ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule NULLEXTERNREF_is_wf_0{ret_val : reftype}: + `%`(ret_val) + -- if (ret_val = $NULLEXTERNREF) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax packtype = @@ -1282,13 +1577,13 @@ syntax Lnn = lanetype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax limits = - | `[%..%]`(v_u64 : u64, u64_opt : u64?) + | mk_limits(v_u64 : u64, u64_opt : u64?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_limits: `%`(limits) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule limits_case_0{v_u64 : u64, u64_opt : u64?}: - `%`(`[%..%]`_limits(v_u64, u64_opt)) + `%`(mk_limits_limits(v_u64, u64_opt)) -- wf_uN: `%%`(64, v_u64) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1296,13 +1591,13 @@ syntax tagtype = typeuse ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax globaltype = - | `%%`(mut_opt : mut?, v_valtype : valtype) + | mk_globaltype(mut_opt : mut?, v_valtype : valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_globaltype: `%`(globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule globaltype_case_0{mut_opt : mut?, v_valtype : valtype}: - `%`(`%%`_globaltype(mut_opt, v_valtype)) + `%`(mk_globaltype_globaltype(mut_opt, v_valtype)) -- wf_valtype: `%`(v_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1318,13 +1613,13 @@ relation wf_memtype: `%`(memtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax tabletype = - | `%%%`(v_addrtype : addrtype, v_limits : limits, v_reftype : reftype) + | mk_tabletype(v_addrtype : addrtype, v_limits : limits, v_reftype : reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_tabletype: `%`(tabletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule tabletype_case_0{v_addrtype : addrtype, v_limits : limits, v_reftype : reftype}: - `%`(`%%%`_tabletype(v_addrtype, v_limits, v_reftype)) + `%`(mk_tabletype_tabletype(v_addrtype, v_limits, v_reftype)) -- wf_limits: `%`(v_limits) -- wf_reftype: `%`(v_reftype) @@ -1372,13 +1667,13 @@ relation wf_externtype: `%`(externtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax moduletype = - | `%->%`(externtype_lst : externtype*, externtype_lst : externtype*) + | mk_moduletype(externtype_lst : externtype*, externtype_lst : externtype*) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation wf_moduletype: `%`(moduletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule moduletype_case_0{externtype_lst : externtype*, externtype_lst_0 : externtype*}: - `%`(`%->%`_moduletype(externtype_lst, externtype_lst_0)) + `%`(mk_moduletype_moduletype(externtype_lst, externtype_lst_0)) -- (wf_externtype: `%`(v_externtype))*{v_externtype <- externtype_lst} -- (wf_externtype: `%`(externtype_lst_0))*{externtype_lst_0 <- externtype_lst_0} @@ -1501,7 +1796,7 @@ def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize{v_n : nat}(v_n) = $Jnn_addrtype(iter_val#1)?{iter_val#1 <- $inv_isize(v_n)} + def $inv_jsize{v_n : nat}(v_n) = $Jnn_addrtype(iter_val_1)?{iter_val_1 <- $inv_isize(v_n)} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $inv_fsize(nat : nat) : Fnn? @@ -1595,10 +1890,17 @@ def $unpack(v_storagetype : storagetype) : valtype def $unpack(I32_storagetype) = I32_valtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I8_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $unpack(I16_storagetype) = I32_valtype - -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation unpack_is_wf: `%%`(v_storagetype : storagetype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule unpack_is_wf_0{v_storagetype : storagetype, ret_val : valtype}: + `%%`(v_storagetype, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- if (ret_val = $unpack(v_storagetype)) + -- wf_valtype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $nunpack(v_storagetype : storagetype) : numtype? @@ -1664,10 +1966,18 @@ def $minat(v_addrtype : addrtype, v_addrtype_0 : addrtype) : addrtype def $diffrt(v_reftype : reftype, v_reftype_0 : reftype) : reftype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{null_1_opt : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1_opt, ht_1), REF_reftype(?(NULL_null), ht_2)) = REF_reftype(?(), ht_1) - -- wf_reftype: `%`(REF_reftype(?(), ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $diffrt{null_1_opt : null?, ht_1 : heaptype, ht_2 : heaptype}(REF_reftype(null_1_opt, ht_1), REF_reftype(?(), ht_2)) = REF_reftype(null_1_opt, ht_1) - -- wf_reftype: `%`(REF_reftype(null_1_opt, ht_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation diffrt_is_wf: `%%%`(v_reftype : reftype, reftype_0 : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule diffrt_is_wf_0{v_reftype : reftype, reftype_0 : reftype, ret_val : reftype}: + `%%%`(v_reftype, reftype_0, ret_val) + -- wf_reftype: `%`(v_reftype) + -- wf_reftype: `%`(reftype_0) + -- if (ret_val = $diffrt(v_reftype, reftype_0)) + -- wf_reftype: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $as_deftype(v_typeuse : typeuse) : deftype? @@ -1679,85 +1989,196 @@ def $as_deftype(v_typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.1-308.87 -def $tagsxt(var_0 : externtype*) : tagtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:314.1-314.23 - def $tagsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:315.1-315.44 - def $tagsxt{jt : typeuse, xt_lst : externtype*}([TAG_externtype(jt)] ++ xt_lst) = [jt] ++ $tagsxt(xt_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:316.1-316.57 - def $tagsxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $tagsxt(xt_lst) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 +relation fun_tagsxt: `%%`(externtype*, tagtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_1{jt : typeuse, xt_lst : externtype*, var_0 : tagtype*}: + `%%`([TAG_externtype(jt)] ++ xt_lst, [jt] ++ var_0) + -- fun_tagsxt: `%%`(xt_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:308.6-308.13 + rule fun_tagsxt_case_2{v_externtype : externtype, xt_lst : externtype*, var_0 : tagtype*}: + `%%`([v_externtype] ++ xt_lst, var_0) + -- fun_tagsxt: `%%`(xt_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.1-309.90 -def $globalsxt(var_0 : externtype*) : globaltype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:318.1-318.26 - def $globalsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:319.1-319.53 - def $globalsxt{gt : globaltype, xt_lst : externtype*}([GLOBAL_externtype(gt)] ++ xt_lst) = [gt] ++ $globalsxt(xt_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:320.1-320.63 - def $globalsxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $globalsxt(xt_lst) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation fun_globalsxt: `%%`(externtype*, globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_1{gt : globaltype, xt_lst : externtype*, var_0 : globaltype*}: + `%%`([GLOBAL_externtype(gt)] ++ xt_lst, [gt] ++ var_0) + -- fun_globalsxt: `%%`(xt_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule fun_globalsxt_case_2{v_externtype : externtype, xt_lst : externtype*, var_0 : globaltype*}: + `%%`([v_externtype] ++ xt_lst, var_0) + -- fun_globalsxt: `%%`(xt_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.1-310.87 -def $memsxt(var_0 : externtype*) : memtype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:322.1-322.23 - def $memsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:323.1-323.44 - def $memsxt{mt : memtype, xt_lst : externtype*}([MEM_externtype(mt)] ++ xt_lst) = [mt] ++ $memsxt(xt_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:324.1-324.57 - def $memsxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $memsxt(xt_lst) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 +relation globalsxt_is_wf: `%%`(var_0 : externtype*, ret_val : globaltype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:309.6-309.16 + rule globalsxt_is_wf_0{var_0 : externtype*, ret_val : globaltype*, var_1 : globaltype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_globaltype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.1-311.89 -def $tablesxt(var_0 : externtype*) : tabletype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:326.1-326.25 - def $tablesxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:327.1-327.50 - def $tablesxt{tt : tabletype, xt_lst : externtype*}([TABLE_externtype(tt)] ++ xt_lst) = [tt] ++ $tablesxt(xt_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:328.1-328.61 - def $tablesxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $tablesxt(xt_lst) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation fun_memsxt: `%%`(externtype*, memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_1{mt : memtype, xt_lst : externtype*, var_0 : memtype*}: + `%%`([MEM_externtype(mt)] ++ xt_lst, [mt] ++ var_0) + -- fun_memsxt: `%%`(xt_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule fun_memsxt_case_2{v_externtype : externtype, xt_lst : externtype*, var_0 : memtype*}: + `%%`([v_externtype] ++ xt_lst, var_0) + -- fun_memsxt: `%%`(xt_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.1-312.88 -def $funcsxt(var_0 : externtype*) : deftype* - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:330.1-330.24 - def $funcsxt([]) = [] - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:331.1-331.47 - def $funcsxt{v_rectype : rectype, v_n : n, xt_lst : externtype*}([FUNC_externtype(_DEF_typeuse(v_rectype, v_n))] ++ xt_lst) = [_DEF_deftype(v_rectype, v_n)] ++ $funcsxt(xt_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:332.1-332.59 - def $funcsxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $funcsxt(xt_lst) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 +relation memsxt_is_wf: `%%`(var_0 : externtype*, ret_val : memtype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:310.6-310.13 + rule memsxt_is_wf_0{var_0 : externtype*, ret_val : memtype*, var_1 : memtype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_memtype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.1-337.126 -def $subst_typevar(v_typevar : typevar, var_0 : typevar*, var_1 : typeuse*) : typeuse? - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:365.1-365.38 - def $subst_typevar{tv : typevar}(tv, [], []) = ?($typeuse_typevar(tv)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:366.1-366.95 - def $subst_typevar{tv : typevar, tv_1 : typevar, tv'_lst : typevar*, tu_1 : typeuse, tu'_lst : typeuse*}(tv, [tv_1] ++ tv'_lst, [tu_1] ++ tu'_lst) = (if (tv = tv_1) then tu_1 else iter_val#2)?{iter_val#2 <- $subst_typevar(tv, tv'_lst, tu'_lst)} - def $subst_typevar{x0 : typevar, x1 : typevar*, x2 : typeuse*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation fun_tablesxt: `%%`(externtype*, tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_1{tt : tabletype, xt_lst : externtype*, var_0 : tabletype*}: + `%%`([TABLE_externtype(tt)] ++ xt_lst, [tt] ++ var_0) + -- fun_tablesxt: `%%`(xt_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule fun_tablesxt_case_2{v_externtype : externtype, xt_lst : externtype*, var_0 : tabletype*}: + `%%`([v_externtype] ++ xt_lst, var_0) + -- fun_tablesxt: `%%`(xt_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 +relation tablesxt_is_wf: `%%`(var_0 : externtype*, ret_val : tabletype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:311.6-311.15 + rule tablesxt_is_wf_0{var_0 : externtype*, ret_val : tabletype*, var_1 : tabletype*}: + `%%`(var_0, ret_val) + -- (wf_externtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tabletype: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesxt: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 +relation fun_funcsxt: `%%`(externtype*, deftype*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_1{v_rectype : rectype, v_n : n, xt_lst : externtype*, var_0 : deftype*}: + `%%`([FUNC_externtype(_DEF_typeuse(v_rectype, v_n))] ++ xt_lst, [_DEF_deftype(v_rectype, v_n)] ++ var_0) + -- fun_funcsxt: `%%`(xt_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:312.6-312.14 + rule fun_funcsxt_case_2{v_externtype : externtype, xt_lst : externtype*, var_0 : deftype*}: + `%%`([v_externtype] ++ xt_lst, var_0) + -- fun_funcsxt: `%%`(xt_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(typevar, typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, tv'_lst : typevar*, tu_1 : typeuse, tu'_lst : typeuse*, var_0 : typeuse?}: + `%%%`(tv, [tv_1] ++ tv'_lst, [tu_1] ++ tu'_lst) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%`(tv, [], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation fun_subst_typevar: `%%%%`(typevar, typevar*, typeuse*, typeuse?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_0{tv : typevar}: + `%%%%`(tv, [], [], ?($typeuse_typevar(tv))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_1{tv : typevar, tv_1 : typevar, tv'_lst : typevar*, tu_1 : typeuse, tu'_lst : typeuse*, var_0 : typeuse?}: + `%%%%`(tv, [tv_1] ++ tv'_lst, [tu_1] ++ tu'_lst, (if (tv = tv_1) then tu_1 else iter_val_2)?{iter_val_2 <- var_0}) + -- fun_subst_typevar: `%%%%`(tv, tv'_lst, tu'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule fun_subst_typevar_case_2{x0 : typevar, x1 : typevar*, x2 : typeuse*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_subst_typevar_before_fun_subst_typevar_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 +relation subst_typevar_is_wf: `%%%%`(v_typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:337.6-337.20 + rule subst_typevar_is_wf_0{v_typevar : typevar, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse?}: + `%%%%`(v_typevar, var_0, var_1, ret_val) + -- wf_typevar: `%`(v_typevar) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typevar: `%%%%`(v_typevar, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.73 +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.1-401.87 def $minus_recs(var_0 : typevar*, var_1 : typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:402.1-402.39 def $minus_recs([], []) = ?(([], [])) @@ -1766,11 +2187,26 @@ def $minus_recs(var_0 : typevar*, var_1 : typeuse*) : (typevar*, typeuse*)? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:404.1-405.45 def $minus_recs{x : uN, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*}([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst) = ?(([_IDX_typevar(x)] ++ tv'_lst, [tu_1] ++ tu'_lst)) -- let{tv'_lst : typevar*, tu'_lst : typeuse*} (tv'_lst, tu'_lst) = !($minus_recs(tv_lst, tu_lst)) - -- wf_typevar: `%`(_IDX_typevar(x)) def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() -- otherwise } +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation minus_recs_is_wf: `%%%`(var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule minus_recs_is_wf_0{var_0 : typevar*, var_1 : typeuse*, ret_val : (typevar*, typeuse*)}: + `%%%`(var_0, var_1, ret_val) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !($minus_recs(var_0, var_1))) + -- if ($minus_recs(var_0, var_1) =/= ?()) + -- (wf_typevar: `%`(iter))*{iter <- ret_val.0} + -- (wf_typeuse: `%`(iter))*{iter <- ret_val.1} +} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_packtype(v_packtype : packtype, var_0 : typevar*, var_1 : typeuse*) : packtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1789,105 +2225,284 @@ def $subst_vectype(v_vectype : vectype, var_0 : typevar*, var_1 : typeuse*) : ve ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.1-338.112 -def $subst_typeuse(v_typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*) : typeuse - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{v_n : n, tv_lst : typevar*, tu_lst : typeuse*}(REC_typeuse(v_n), tv_lst, tu_lst) = !($subst_typevar(REC_typevar(v_n), tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:369.1-369.66 - def $subst_typeuse{v_typeidx : typeidx, tv_lst : typevar*, tu_lst : typeuse*}(_IDX_typeuse(v_typeidx), tv_lst, tu_lst) = !($subst_typevar(_IDX_typevar(v_typeidx), tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:370.1-370.64 - def $subst_typeuse{v_rectype : rectype, v_n : n, tv_lst : typevar*, tu_lst : typeuse*}(_DEF_typeuse(v_rectype, v_n), tv_lst, tu_lst) = $typeuse_deftype($subst_deftype(_DEF_deftype(v_rectype, v_n), tv_lst, tu_lst)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.1-343.112 -def $subst_heaptype(v_heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*) : heaptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{v_n : n, tv_lst : typevar*, tu_lst : typeuse*}(REC_heaptype(v_n), tv_lst, tu_lst) = $heaptype_typeuse(!($subst_typevar(REC_typevar(v_n), tv_lst, tu_lst))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:376.1-376.67 - def $subst_heaptype{v_typeidx : typeidx, tv_lst : typevar*, tu_lst : typeuse*}(_IDX_heaptype(v_typeidx), tv_lst, tu_lst) = $heaptype_typeuse(!($subst_typevar(_IDX_typevar(v_typeidx), tv_lst, tu_lst))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:377.1-377.65 - def $subst_heaptype{v_rectype : rectype, v_n : n, tv_lst : typevar*, tu_lst : typeuse*}(_DEF_heaptype(v_rectype, v_n), tv_lst, tu_lst) = $heaptype_deftype($subst_deftype(_DEF_deftype(v_rectype, v_n), tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:378.1-378.53 - def $subst_heaptype{ht : heaptype, tv_lst : typevar*, tu_lst : typeuse*}(ht, tv_lst, tu_lst) = ht - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.1-344.112 -def $subst_reftype(v_reftype : reftype, var_0 : typevar*, var_1 : typeuse*) : reftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:380.1-380.87 - def $subst_reftype{null_opt : null?, ht : heaptype, tv_lst : typevar*, tu_lst : typeuse*}(REF_reftype(null_opt, ht), tv_lst, tu_lst) = REF_reftype(null_opt, $subst_heaptype(ht, tv_lst, tu_lst)) - -- wf_reftype: `%`(REF_reftype(null_opt, $subst_heaptype(ht, tv_lst, tu_lst))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.1-345.112 -def $subst_valtype(v_valtype : valtype, var_0 : typevar*, var_1 : typeuse*) : valtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(I32_valtype, tv_lst, tu_lst) = $valtype_numtype($subst_numtype(I32_numtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(I64_valtype, tv_lst, tu_lst) = $valtype_numtype($subst_numtype(I64_numtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(F32_valtype, tv_lst, tu_lst) = $valtype_numtype($subst_numtype(F32_numtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:382.1-382.64 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(F64_valtype, tv_lst, tu_lst) = $valtype_numtype($subst_numtype(F64_numtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:383.1-383.64 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(V128_valtype, tv_lst, tu_lst) = $valtype_vectype($subst_vectype(V128_vectype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:384.1-384.64 - def $subst_valtype{null_opt : null?, v_heaptype : heaptype, tv_lst : typevar*, tu_lst : typeuse*}(REF_valtype(null_opt, v_heaptype), tv_lst, tu_lst) = $valtype_reftype($subst_reftype(REF_reftype(null_opt, v_heaptype), tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:385.1-385.40 - def $subst_valtype{tv_lst : typevar*, tu_lst : typeuse*}(BOT_valtype, tv_lst, tu_lst) = BOT_valtype - -- wf_valtype: `%`(BOT_valtype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.1-348.112 -def $subst_storagetype(v_storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*) : storagetype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(BOT_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(BOT_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{null_opt : null?, v_heaptype : heaptype, tv_lst : typevar*, tu_lst : typeuse*}(REF_storagetype(null_opt, v_heaptype), tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(REF_valtype(null_opt, v_heaptype), tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(V128_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(V128_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(F64_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(F64_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(F32_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(F32_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(I64_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(I64_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:389.1-389.66 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(I32_storagetype, tv_lst, tu_lst) = $storagetype_valtype($subst_valtype(I32_valtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(I8_storagetype, tv_lst, tu_lst) = $storagetype_packtype($subst_packtype(I8_packtype, tv_lst, tu_lst)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:390.1-390.69 - def $subst_storagetype{tv_lst : typevar*, tu_lst : typeuse*}(I16_storagetype, tv_lst, tu_lst) = $storagetype_packtype($subst_packtype(I16_packtype, tv_lst, tu_lst)) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.1-349.112 -def $subst_fieldtype(v_fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*) : fieldtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:392.1-392.82 - def $subst_fieldtype{mut_opt : mut?, zt : storagetype, tv_lst : typevar*, tu_lst : typeuse*}(`%%`_fieldtype(mut_opt, zt), tv_lst, tu_lst) = `%%`_fieldtype(mut_opt, $subst_storagetype(zt, tv_lst, tu_lst)) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, $subst_storagetype(zt, tv_lst, tu_lst))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.1-351.112 -def $subst_comptype(v_comptype : comptype, var_0 : typevar*, var_1 : typeuse*) : comptype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:394.1-394.85 - def $subst_comptype{ft_lst : fieldtype*, tv_lst : typevar*, tu_lst : typeuse*}(STRUCT_comptype(`%`_list(ft_lst)), tv_lst, tu_lst) = STRUCT_comptype(`%`_list($subst_fieldtype(ft, tv_lst, tu_lst)*{ft <- ft_lst})) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list($subst_fieldtype(ft#2, tv_lst, tu_lst)*{ft#2 <- ft_lst}))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:395.1-395.81 - def $subst_comptype{ft : fieldtype, tv_lst : typevar*, tu_lst : typeuse*}(ARRAY_comptype(ft), tv_lst, tu_lst) = ARRAY_comptype($subst_fieldtype(ft, tv_lst, tu_lst)) - -- wf_comptype: `%`(ARRAY_comptype($subst_fieldtype(ft, tv_lst, tu_lst))) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:396.1-396.123 - def $subst_comptype{t_1_lst : valtype*, t_2_lst : valtype*, tv_lst : typevar*, tu_lst : typeuse*}(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)), tv_lst, tu_lst) = `FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1, tv_lst, tu_lst)*{t_1 <- t_1_lst}), `%`_resulttype($subst_valtype(t_2, tv_lst, tu_lst)*{t_2 <- t_2_lst})) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype($subst_valtype(t_1#2, tv_lst, tu_lst)*{t_1#2 <- t_1_lst}), `%`_resulttype($subst_valtype(t_2#2, tv_lst, tu_lst)*{t_2#2 <- t_2_lst}))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.1-352.112 -def $subst_subtype(v_subtype : subtype, var_0 : typevar*, var_1 : typeuse*) : subtype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:398.1-399.74 - def $subst_subtype{final_opt : final?, tu'_lst : typeuse*, ct : comptype, tv_lst : typevar*, tu_lst : typeuse*}(SUB_subtype(final_opt, tu'_lst, ct), tv_lst, tu_lst) = SUB_subtype(final_opt, $subst_typeuse(tu', tv_lst, tu_lst)*{tu' <- tu'_lst}, $subst_comptype(ct, tv_lst, tu_lst)) - -- wf_subtype: `%`(SUB_subtype(final_opt, $subst_typeuse(tu'#4, tv_lst, tu_lst)*{tu'#4 <- tu'_lst}, $subst_comptype(ct, tv_lst, tu_lst))) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.1-353.112 -def $subst_rectype(v_rectype : rectype, var_0 : typevar*, var_1 : typeuse*) : rectype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:407.1-408.45 - def $subst_rectype{st_lst : subtype*, tv_lst : typevar*, tu_lst : typeuse*}(REC_rectype(`%`_list(st_lst)), tv_lst, tu_lst) = REC_rectype(`%`_list($subst_subtype(st, tv'_lst, tu'_lst)*{st <- st_lst})) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation fun_subst_typeuse: `%%%%`(typeuse, typevar*, typeuse*, typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_0{v_n : n, tv_lst : typevar*, tu_lst : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_typeuse(v_n), tv_lst, tu_lst, !(var_0)) + -- fun_subst_typevar: `%%%%`(REC_typevar(v_n), tv_lst, tu_lst, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_1{v_typeidx : typeidx, tv_lst : typevar*, tu_lst : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_typeuse(v_typeidx), tv_lst, tu_lst, !(var_0)) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(v_typeidx), tv_lst, tu_lst, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule fun_subst_typeuse_case_2{v_rectype : rectype, v_n : n, tv_lst : typevar*, tu_lst : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_typeuse(v_rectype, v_n), tv_lst, tu_lst, $typeuse_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(v_rectype, v_n), tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation fun_subst_heaptype: `%%%%`(heaptype, typevar*, typeuse*, heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_0{v_n : n, tv_lst : typevar*, tu_lst : typeuse*, var_0 : typeuse?}: + `%%%%`(REC_heaptype(v_n), tv_lst, tu_lst, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(REC_typevar(v_n), tv_lst, tu_lst, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_1{v_typeidx : typeidx, tv_lst : typevar*, tu_lst : typeuse*, var_0 : typeuse?}: + `%%%%`(_IDX_heaptype(v_typeidx), tv_lst, tu_lst, $heaptype_typeuse(!(var_0))) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(v_typeidx), tv_lst, tu_lst, var_0) + -- if (var_0 =/= ?()) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_2{v_rectype : rectype, v_n : n, tv_lst : typevar*, tu_lst : typeuse*, var_0 : deftype}: + `%%%%`(_DEF_heaptype(v_rectype, v_n), tv_lst, tu_lst, $heaptype_deftype(var_0)) + -- fun_subst_deftype: `%%%%`(_DEF_deftype(v_rectype, v_n), tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule fun_subst_heaptype_case_3{ht : heaptype, tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(ht, tv_lst, tu_lst, ht) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation fun_subst_reftype: `%%%%`(reftype, typevar*, typeuse*, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule fun_subst_reftype_case_0{null_opt : null?, ht : heaptype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : heaptype}: + `%%%%`(REF_reftype(null_opt, ht), tv_lst, tu_lst, REF_reftype(null_opt, var_0)) + -- fun_subst_heaptype: `%%%%`(ht, tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_0{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(I32_valtype, tv_lst, tu_lst, $valtype_numtype($subst_numtype(I32_numtype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_1{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(I64_valtype, tv_lst, tu_lst, $valtype_numtype($subst_numtype(I64_numtype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_2{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(F32_valtype, tv_lst, tu_lst, $valtype_numtype($subst_numtype(F32_numtype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_3{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(F64_valtype, tv_lst, tu_lst, $valtype_numtype($subst_numtype(F64_numtype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_4{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(V128_valtype, tv_lst, tu_lst, $valtype_vectype($subst_vectype(V128_vectype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_5{null_opt : null?, v_heaptype : heaptype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : reftype}: + `%%%%`(REF_valtype(null_opt, v_heaptype), tv_lst, tu_lst, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(null_opt, v_heaptype), tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule fun_subst_valtype_case_6{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(BOT_valtype, tv_lst, tu_lst, BOT_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation fun_subst_storagetype: `%%%%`(storagetype, typevar*, typeuse*, storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_0{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(BOT_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_1{null_opt : null?, v_heaptype : heaptype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(REF_storagetype(null_opt, v_heaptype), tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(null_opt, v_heaptype), tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_2{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(V128_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_3{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(F64_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_4{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(F32_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_5{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(I64_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_6{tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(I32_storagetype, tv_lst, tu_lst, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_7{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(I8_storagetype, tv_lst, tu_lst, $storagetype_packtype($subst_packtype(I8_packtype, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule fun_subst_storagetype_case_8{tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(I16_storagetype, tv_lst, tu_lst, $storagetype_packtype($subst_packtype(I16_packtype, tv_lst, tu_lst))) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation fun_subst_fieldtype: `%%%%`(fieldtype, typevar*, typeuse*, fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule fun_subst_fieldtype_case_0{mut_opt : mut?, zt : storagetype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : storagetype}: + `%%%%`(mk_fieldtype_fieldtype(mut_opt, zt), tv_lst, tu_lst, mk_fieldtype_fieldtype(mut_opt, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_0{ft_lst : fieldtype*, tv_lst : typevar*, tu_lst : typeuse*, var_0_lst : fieldtype*}: + `%%%%`(STRUCT_comptype(mk_list_list(ft_lst)), tv_lst, tu_lst, STRUCT_comptype(mk_list_list(var_0_lst))) + -- (fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, ft <- ft_lst} + -- if (|var_0_lst| = |ft_lst|) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_1{ft : fieldtype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv_lst, tu_lst, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule fun_subst_comptype_case_2{t_1_lst : valtype*, t_2_lst : valtype*, tv_lst : typevar*, tu_lst : typeuse*, var_1_lst : valtype*, var_0_lst : valtype*}: + `%%%%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)), tv_lst, tu_lst, `FUNC%->%`_comptype(mk_list_resulttype(var_0_lst), mk_list_resulttype(var_1_lst))) + -- (fun_subst_valtype: `%%%%`(t_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, t_2 <- t_2_lst} + -- if (|var_1_lst| = |t_2_lst|) + -- (fun_subst_valtype: `%%%%`(t_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, t_1 <- t_1_lst} + -- if (|var_0_lst| = |t_1_lst|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation fun_subst_subtype: `%%%%`(subtype, typevar*, typeuse*, subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule fun_subst_subtype_case_0{final_opt : final?, tu'_lst : typeuse*, ct : comptype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : comptype, var_0_lst : typeuse*}: + `%%%%`(SUB_subtype(final_opt, tu'_lst, ct), tv_lst, tu_lst, SUB_subtype(final_opt, var_0_lst, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv_lst, tu_lst, var_1) + -- (fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, tu' <- tu'_lst} + -- if (|var_0_lst| = |tu'_lst|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 +relation fun_subst_rectype: `%%%%`(rectype, typevar*, typeuse*, rectype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:353.6-353.20 + rule fun_subst_rectype_case_0{st_lst : subtype*, tv_lst : typevar*, tu_lst : typeuse*, var_0_lst : subtype*}: + `%%%%`(REC_rectype(mk_list_list(st_lst)), tv_lst, tu_lst, REC_rectype(mk_list_list(var_0_lst))) -- let{tv'_lst : typevar*, tu'_lst : typeuse*} (tv'_lst, tu'_lst) = !($minus_recs(tv_lst, tu_lst)) + -- if ($minus_recs(tv_lst, tu_lst) =/= ?()) + -- (fun_subst_subtype: `%%%%`(st, tv'_lst, tu'_lst, var_0))*{var_0 <- var_0_lst, st <- st_lst} + -- if (|var_0_lst| = |st_lst|) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 +relation fun_subst_deftype: `%%%%`(deftype, typevar*, typeuse*, deftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 + rule fun_subst_deftype_case_0{qt : rectype, i : nat, tv_lst : typevar*, tu_lst : typeuse*, var_0 : rectype}: + `%%%%`(_DEF_deftype(qt, i), tv_lst, tu_lst, _DEF_deftype(var_0, i)) + -- fun_subst_rectype: `%%%%`(qt, tv_lst, tu_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.1-354.112 -def $subst_deftype(v_deftype : deftype, var_0 : typevar*, var_1 : typeuse*) : deftype - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:413.1-413.80 - def $subst_deftype{qt : rectype, i : nat, tv_lst : typevar*, tu_lst : typeuse*}(_DEF_deftype(qt, i), tv_lst, tu_lst) = _DEF_deftype($subst_rectype(qt, tv_lst, tu_lst), i) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 +relation subst_typeuse_is_wf: `%%%%`(v_typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:338.6-338.20 + rule subst_typeuse_is_wf_0{v_typeuse : typeuse, var_0 : typevar*, var_1 : typeuse*, ret_val : typeuse, var_2 : typeuse}: + `%%%%`(v_typeuse, var_0, var_1, ret_val) + -- wf_typeuse: `%`(v_typeuse) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_typeuse: `%`(ret_val) + -- fun_subst_typeuse: `%%%%`(v_typeuse, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 +relation subst_heaptype_is_wf: `%%%%`(v_heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:343.6-343.21 + rule subst_heaptype_is_wf_0{v_heaptype : heaptype, var_0 : typevar*, var_1 : typeuse*, ret_val : heaptype, var_2 : heaptype}: + `%%%%`(v_heaptype, var_0, var_1, ret_val) + -- wf_heaptype: `%`(v_heaptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_heaptype: `%`(ret_val) + -- fun_subst_heaptype: `%%%%`(v_heaptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 +relation subst_reftype_is_wf: `%%%%`(v_reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:344.6-344.20 + rule subst_reftype_is_wf_0{v_reftype : reftype, var_0 : typevar*, var_1 : typeuse*, ret_val : reftype, var_2 : reftype}: + `%%%%`(v_reftype, var_0, var_1, ret_val) + -- wf_reftype: `%`(v_reftype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_reftype: `%`(ret_val) + -- fun_subst_reftype: `%%%%`(v_reftype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 +relation subst_valtype_is_wf: `%%%%`(v_valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 + rule subst_valtype_is_wf_0{v_valtype : valtype, var_0 : typevar*, var_1 : typeuse*, ret_val : valtype, var_2 : valtype}: + `%%%%`(v_valtype, var_0, var_1, ret_val) + -- wf_valtype: `%`(v_valtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_valtype: `%`(ret_val) + -- fun_subst_valtype: `%%%%`(v_valtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 +relation subst_storagetype_is_wf: `%%%%`(v_storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:348.6-348.24 + rule subst_storagetype_is_wf_0{v_storagetype : storagetype, var_0 : typevar*, var_1 : typeuse*, ret_val : storagetype, var_2 : storagetype}: + `%%%%`(v_storagetype, var_0, var_1, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_storagetype: `%`(ret_val) + -- fun_subst_storagetype: `%%%%`(v_storagetype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 +relation subst_fieldtype_is_wf: `%%%%`(v_fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:349.6-349.22 + rule subst_fieldtype_is_wf_0{v_fieldtype : fieldtype, var_0 : typevar*, var_1 : typeuse*, ret_val : fieldtype, var_2 : fieldtype}: + `%%%%`(v_fieldtype, var_0, var_1, ret_val) + -- wf_fieldtype: `%`(v_fieldtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_fieldtype: `%`(ret_val) + -- fun_subst_fieldtype: `%%%%`(v_fieldtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 +relation subst_comptype_is_wf: `%%%%`(v_comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:351.6-351.21 + rule subst_comptype_is_wf_0{v_comptype : comptype, var_0 : typevar*, var_1 : typeuse*, ret_val : comptype, var_2 : comptype}: + `%%%%`(v_comptype, var_0, var_1, ret_val) + -- wf_comptype: `%`(v_comptype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_comptype: `%`(ret_val) + -- fun_subst_comptype: `%%%%`(v_comptype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 +relation subst_subtype_is_wf: `%%%%`(v_subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:352.6-352.20 + rule subst_subtype_is_wf_0{v_subtype : subtype, var_0 : typevar*, var_1 : typeuse*, ret_val : subtype, var_2 : subtype}: + `%%%%`(v_subtype, var_0, var_1, ret_val) + -- wf_subtype: `%`(v_subtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_subtype: `%`(ret_val) + -- fun_subst_subtype: `%%%%`(v_subtype, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1896,161 +2511,370 @@ def $subst_addrtype(v_addrtype : addrtype, var_0 : typevar*, var_1 : typeuse*) : def $subst_addrtype{at : addrtype, tv_lst : typevar*, tu_lst : typeuse*}(at, tv_lst, tu_lst) = at ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tagtype(v_tagtype : tagtype, var_0 : typevar*, var_1 : typeuse*) : tagtype +relation fun_subst_tagtype: `%%%%`(tagtype, typevar*, typeuse*, tagtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_tagtype_case_0{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_0 : tagtype}: + `%%%%`(tu', tv_lst, tu_lst, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tagtype{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*}(tu', tv_lst, tu_lst) = $subst_typeuse(tu', tv_lst, tu_lst) + rule fun_subst_globaltype_case_0{mut_opt : mut?, t : valtype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : valtype}: + `%%%%`(mk_globaltype_globaltype(mut_opt, t), tv_lst, tu_lst, mk_globaltype_globaltype(mut_opt, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv_lst, tu_lst, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_globaltype(v_globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*) : globaltype +relation subst_globaltype_is_wf: `%%%%`(v_globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_globaltype{mut_opt : mut?, t : valtype, tv_lst : typevar*, tu_lst : typeuse*}(`%%`_globaltype(mut_opt, t), tv_lst, tu_lst) = `%%`_globaltype(mut_opt, $subst_valtype(t, tv_lst, tu_lst)) - -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, $subst_valtype(t, tv_lst, tu_lst))) + rule subst_globaltype_is_wf_0{v_globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*, ret_val : globaltype, var_2 : globaltype}: + `%%%%`(v_globaltype, var_0, var_1, ret_val) + -- wf_globaltype: `%`(v_globaltype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_globaltype: `%`(ret_val) + -- fun_subst_globaltype: `%%%%`(v_globaltype, var_0, var_1, var_2) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype(v_memtype : memtype, var_0 : typevar*, var_1 : typeuse*) : memtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $subst_memtype{at : addrtype, lim : limits, tv_lst : typevar*, tu_lst : typeuse*}(`%%PAGE`_memtype(at, lim), tv_lst, tu_lst) = `%%PAGE`_memtype(at, lim) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(v_tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*) : tabletype +relation subst_memtype_is_wf: `%%%%`(v_memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_memtype_is_wf_0{v_memtype : memtype, var_0 : typevar*, var_1 : typeuse*, ret_val : memtype}: + `%%%%`(v_memtype, var_0, var_1, ret_val) + -- wf_memtype: `%`(v_memtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = $subst_memtype(v_memtype, var_0, var_1)) + -- wf_memtype: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_tabletype: `%%%%`(tabletype, typevar*, typeuse*, tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : reftype}: + `%%%%`(mk_tabletype_tabletype(at, lim, rt), tv_lst, tu_lst, mk_tabletype_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_tabletype_is_wf: `%%%%`(v_tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_tabletype_is_wf_0{v_tabletype : tabletype, var_0 : typevar*, var_1 : typeuse*, ret_val : tabletype, var_2 : tabletype}: + `%%%%`(v_tabletype, var_0, var_1, ret_val) + -- wf_tabletype: `%`(v_tabletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_tabletype: `%`(ret_val) + -- fun_subst_tabletype: `%%%%`(v_tabletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_externtype: `%%%%`(externtype, typevar*, typeuse*, externtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_tabletype{at : addrtype, lim : limits, rt : reftype, tv_lst : typevar*, tu_lst : typeuse*}(`%%%`_tabletype(at, lim, rt), tv_lst, tu_lst) = `%%%`_tabletype(at, lim, $subst_reftype(rt, tv_lst, tu_lst)) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, $subst_reftype(rt, tv_lst, tu_lst))) + rule fun_subst_externtype_case_0{jt : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv_lst, tu_lst, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_1{gt : globaltype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv_lst, tu_lst, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_2{tt : tabletype, tv_lst : typevar*, tu_lst : typeuse*, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv_lst, tu_lst, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_3{mt : memtype, tv_lst : typevar*, tu_lst : typeuse*}: + `%%%%`(MEM_externtype(mt), tv_lst, tu_lst, MEM_externtype($subst_memtype(mt, tv_lst, tu_lst))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_4{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv_lst, tu_lst, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation subst_externtype_is_wf: `%%%%`(v_externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule subst_externtype_is_wf_0{v_externtype : externtype, var_0 : typevar*, var_1 : typeuse*, ret_val : externtype, var_2 : externtype}: + `%%%%`(v_externtype, var_0, var_1, ret_val) + -- wf_externtype: `%`(v_externtype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_externtype: `%`(ret_val) + -- fun_subst_externtype: `%%%%`(v_externtype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_moduletype_case_0{xt_1_lst : externtype*, xt_2_lst : externtype*, tv_lst : typevar*, tu_lst : typeuse*, var_1_lst : externtype*, var_0_lst : externtype*}: + `%%%%`(mk_moduletype_moduletype(xt_1_lst, xt_2_lst), tv_lst, tu_lst, mk_moduletype_moduletype(var_0_lst, var_1_lst)) + -- (fun_subst_externtype: `%%%%`(xt_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, xt_2 <- xt_2_lst} + -- if (|var_1_lst| = |xt_2_lst|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, xt_1 <- xt_1_lst} + -- if (|var_0_lst| = |xt_1_lst|) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(v_externtype : externtype, var_0 : typevar*, var_1 : typeuse*) : externtype +relation subst_moduletype_is_wf: `%%%%`(v_moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{jt : typeuse, tv_lst : typevar*, tu_lst : typeuse*}(TAG_externtype(jt), tv_lst, tu_lst) = TAG_externtype($subst_tagtype(jt, tv_lst, tu_lst)) - -- wf_externtype: `%`(TAG_externtype($subst_tagtype(jt, tv_lst, tu_lst))) + rule subst_moduletype_is_wf_0{v_moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*, ret_val : moduletype, var_2 : moduletype}: + `%%%%`(v_moduletype, var_0, var_1, ret_val) + -- wf_moduletype: `%`(v_moduletype) + -- (wf_typevar: `%`(var_0))*{var_0 <- var_0} + -- (wf_typeuse: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_moduletype: `%`(ret_val) + -- fun_subst_moduletype: `%%%%`(v_moduletype, var_0, var_1, var_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_all_valtype: `%%%`(valtype, typeuse*, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_all_valtype_case_0{t : valtype, v_n : nat, tu_lst : typeuse*, i : nat, var_0 : valtype}: + `%%%`(t, tu_lst, var_0) + -- if (v_n = |tu_lst|) + -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(mk_uN_typeidx(i))^(i%`_moduletype(xt_1_lst, xt_2_lst), tv_lst, tu_lst) = `%->%`_moduletype($subst_externtype(xt_1, tv_lst, tu_lst)*{xt_1 <- xt_1_lst}, $subst_externtype(xt_2, tv_lst, tu_lst)*{xt_2 <- xt_2_lst}) - -- wf_moduletype: `%`(`%->%`_moduletype($subst_externtype(xt_1#2, tv_lst, tu_lst)*{xt_1#2 <- xt_1_lst}, $subst_externtype(xt_2#2, tv_lst, tu_lst)*{xt_2#2 <- xt_2_lst})) + rule fun_subst_all_globaltype_case_0{gt : globaltype, v_n : nat, tu_lst : typeuse*, i : nat, var_0 : globaltype}: + `%%%`(gt, tu_lst, var_0) + -- if (v_n = |tu_lst|) + -- fun_subst_globaltype: `%%%%`(gt, _IDX_typevar(mk_uN_typeidx(i))^(i%`_comptype(resulttype_1, resulttype_2)) = $free_resulttype(resulttype_1) +++ $free_resulttype(resulttype_2) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.1-491.34 -def $free_subtype(v_subtype : subtype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:550.1-551.66 - def $free_subtype{final_opt : final?, typeuse_lst : typeuse*, v_comptype : comptype}(SUB_subtype(final_opt, typeuse_lst, v_comptype)) = $free_list($free_typeuse(v_typeuse)*{v_typeuse <- typeuse_lst}) +++ $free_comptype(v_comptype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.1-492.34 -def $free_rectype(v_rectype : rectype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:553.1-553.70 - def $free_rectype{subtype_lst : subtype*}(REC_rectype(`%`_list(subtype_lst))) = $free_list($free_subtype(v_subtype)*{v_subtype <- subtype_lst}) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.1-520.34 -def $free_deftype(v_deftype : deftype) : free - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:521.1-521.59 - def $free_deftype{v_rectype : rectype, v_n : nat}(_DEF_deftype(v_rectype, v_n)) = $free_rectype(v_rectype) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation fun_free_heaptype: `%%`(heaptype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_0: + `%%`(ANY_heaptype, $free_absheaptype(ANY_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_1: + `%%`(EQ_heaptype, $free_absheaptype(EQ_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_2: + `%%`(I31_heaptype, $free_absheaptype(I31_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_3: + `%%`(STRUCT_heaptype, $free_absheaptype(STRUCT_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_4: + `%%`(ARRAY_heaptype, $free_absheaptype(ARRAY_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_5: + `%%`(NONE_heaptype, $free_absheaptype(NONE_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_6: + `%%`(FUNC_heaptype, $free_absheaptype(FUNC_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_7: + `%%`(NOFUNC_heaptype, $free_absheaptype(NOFUNC_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_8: + `%%`(EXN_heaptype, $free_absheaptype(EXN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_9: + `%%`(NOEXN_heaptype, $free_absheaptype(NOEXN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_10: + `%%`(EXTERN_heaptype, $free_absheaptype(EXTERN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_11: + `%%`(NOEXTERN_heaptype, $free_absheaptype(NOEXTERN_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_12: + `%%`(BOT_heaptype, $free_absheaptype(BOT_absheaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_13{n_0 : n, var_0 : free}: + `%%`(REC_heaptype(n_0), var_0) + -- fun_free_typeuse: `%%`(REC_typeuse(n_0), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_14{v_rectype : rectype, v_n : n, var_0 : free}: + `%%`(_DEF_heaptype(v_rectype, v_n), var_0) + -- fun_free_typeuse: `%%`(_DEF_typeuse(v_rectype, v_n), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule fun_free_heaptype_case_15{v_typeidx : typeidx, var_0 : free}: + `%%`(_IDX_heaptype(v_typeidx), var_0) + -- fun_free_typeuse: `%%`(_IDX_typeuse(v_typeidx), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation fun_free_reftype: `%%`(reftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule fun_free_reftype_case_0{null_opt : null?, v_heaptype : heaptype, var_0 : free}: + `%%`(REF_reftype(null_opt, v_heaptype), var_0) + -- fun_free_heaptype: `%%`(v_heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation fun_free_typeuse: `%%`(typeuse, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_0{v_n : n}: + `%%`(REC_typeuse(v_n), $free_typevar(REC_typevar(v_n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_1{v_typeidx : typeidx}: + `%%`(_IDX_typeuse(v_typeidx), $free_typevar(_IDX_typevar(v_typeidx))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule fun_free_typeuse_case_2{v_rectype : rectype, v_n : n, var_0 : free}: + `%%`(_DEF_typeuse(v_rectype, v_n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(v_rectype, v_n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation fun_free_valtype: `%%`(valtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_0: + `%%`(I32_valtype, $free_numtype(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_1: + `%%`(I64_valtype, $free_numtype(I64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_2: + `%%`(F32_valtype, $free_numtype(F32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_3: + `%%`(F64_valtype, $free_numtype(F64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_4: + `%%`(V128_valtype, $free_vectype(V128_vectype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_5{null_opt : null?, v_heaptype : heaptype, var_0 : free}: + `%%`(REF_valtype(null_opt, v_heaptype), var_0) + -- fun_free_reftype: `%%`(REF_reftype(null_opt, v_heaptype), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule fun_free_valtype_case_6: + `%%`(BOT_valtype, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation fun_free_resulttype: `%%`(resulttype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule fun_free_resulttype_case_0{valtype_lst : valtype*, var_1_lst : free*, var_0 : free}: + `%%`(mk_list_resulttype(valtype_lst), var_0) + -- (fun_free_valtype: `%%`(v_valtype, var_1))*{var_1 <- var_1_lst, v_valtype <- valtype_lst} + -- if (|var_1_lst| = |valtype_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation fun_free_storagetype: `%%`(storagetype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_0{var_0 : free}: + `%%`(BOT_storagetype, var_0) + -- fun_free_valtype: `%%`(BOT_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_1{null_opt : null?, v_heaptype : heaptype, var_0 : free}: + `%%`(REF_storagetype(null_opt, v_heaptype), var_0) + -- fun_free_valtype: `%%`(REF_valtype(null_opt, v_heaptype), var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_2{var_0 : free}: + `%%`(V128_storagetype, var_0) + -- fun_free_valtype: `%%`(V128_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_3{var_0 : free}: + `%%`(F64_storagetype, var_0) + -- fun_free_valtype: `%%`(F64_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_4{var_0 : free}: + `%%`(F32_storagetype, var_0) + -- fun_free_valtype: `%%`(F32_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_5{var_0 : free}: + `%%`(I64_storagetype, var_0) + -- fun_free_valtype: `%%`(I64_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_6{var_0 : free}: + `%%`(I32_storagetype, var_0) + -- fun_free_valtype: `%%`(I32_valtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_7: + `%%`(I8_storagetype, $free_packtype(I8_packtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_8: + `%%`(I16_storagetype, $free_packtype(I16_packtype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation fun_free_fieldtype: `%%`(fieldtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule fun_free_fieldtype_case_0{mut_opt : mut?, v_storagetype : storagetype, var_0 : free}: + `%%`(mk_fieldtype_fieldtype(mut_opt, v_storagetype), var_0) + -- fun_free_storagetype: `%%`(v_storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation fun_free_comptype: `%%`(comptype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_0{fieldtype_lst : fieldtype*, var_1_lst : free*, var_0 : free}: + `%%`(STRUCT_comptype(mk_list_list(fieldtype_lst)), var_0) + -- (fun_free_fieldtype: `%%`(v_fieldtype, var_1))*{var_1 <- var_1_lst, v_fieldtype <- fieldtype_lst} + -- if (|var_1_lst| = |fieldtype_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_1{v_fieldtype : fieldtype, var_0 : free}: + `%%`(ARRAY_comptype(v_fieldtype), var_0) + -- fun_free_fieldtype: `%%`(v_fieldtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule fun_free_comptype_case_2{resulttype_1 : list(syntax valtype), resulttype_2 : list(syntax valtype), var_1 : free, var_0 : free}: + `%%`(`FUNC%->%`_comptype(resulttype_1, resulttype_2), var_0 +++ var_1) + -- fun_free_resulttype: `%%`(resulttype_2, var_1) + -- fun_free_resulttype: `%%`(resulttype_1, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation fun_free_subtype: `%%`(subtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule fun_free_subtype_case_0{final_opt : final?, typeuse_lst : typeuse*, v_comptype : comptype, var_2 : free, var_1_lst : free*, var_0 : free}: + `%%`(SUB_subtype(final_opt, typeuse_lst, v_comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(v_comptype, var_2) + -- (fun_free_typeuse: `%%`(v_typeuse, var_1))*{var_1 <- var_1_lst, v_typeuse <- typeuse_lst} + -- if (|var_1_lst| = |typeuse_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation fun_free_rectype: `%%`(rectype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule fun_free_rectype_case_0{subtype_lst : subtype*, var_1_lst : free*, var_0 : free}: + `%%`(REC_rectype(mk_list_list(subtype_lst)), var_0) + -- (fun_free_subtype: `%%`(v_subtype, var_1))*{var_1 <- var_1_lst, v_subtype <- subtype_lst} + -- if (|var_1_lst| = |subtype_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation fun_free_deftype: `%%`(deftype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule fun_free_deftype_case_0{v_rectype : rectype, v_n : nat, var_0 : free}: + `%%`(_DEF_deftype(v_rectype, v_n), var_0) + -- fun_free_rectype: `%%`(v_rectype, var_0) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tagtype(v_tagtype : tagtype) : free +rec { + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 +relation free_heaptype_is_wf: `%%`(v_heaptype : heaptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:481.6-481.20 + rule free_heaptype_is_wf_0{v_heaptype : heaptype, ret_val : free, var_0 : free}: + `%%`(v_heaptype, ret_val) + -- wf_heaptype: `%`(v_heaptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_heaptype: `%%`(v_heaptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 +relation free_reftype_is_wf: `%%`(v_reftype : reftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:482.6-482.19 + rule free_reftype_is_wf_0{v_reftype : reftype, ret_val : free, var_0 : free}: + `%%`(v_reftype, ret_val) + -- wf_reftype: `%`(v_reftype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_reftype: `%%`(v_reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 +relation free_typeuse_is_wf: `%%`(v_typeuse : typeuse, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:484.6-484.19 + rule free_typeuse_is_wf_0{v_typeuse : typeuse, ret_val : free, var_0 : free}: + `%%`(v_typeuse, ret_val) + -- wf_typeuse: `%`(v_typeuse) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 +relation free_valtype_is_wf: `%%`(v_valtype : valtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:485.6-485.19 + rule free_valtype_is_wf_0{v_valtype : valtype, ret_val : free, var_0 : free}: + `%%`(v_valtype, ret_val) + -- wf_valtype: `%`(v_valtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_valtype: `%%`(v_valtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 +relation free_resulttype_is_wf: `%%`(v_resulttype : resulttype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:487.6-487.22 + rule free_resulttype_is_wf_0{v_resulttype : resulttype, ret_val : free, var_0 : free}: + `%%`(v_resulttype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_resulttype: `%%`(v_resulttype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 +relation free_storagetype_is_wf: `%%`(v_storagetype : storagetype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule free_storagetype_is_wf_0{v_storagetype : storagetype, ret_val : free, var_0 : free}: + `%%`(v_storagetype, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_storagetype: `%%`(v_storagetype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 +relation free_fieldtype_is_wf: `%%`(v_fieldtype : fieldtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:489.6-489.21 + rule free_fieldtype_is_wf_0{v_fieldtype : fieldtype, ret_val : free, var_0 : free}: + `%%`(v_fieldtype, ret_val) + -- wf_fieldtype: `%`(v_fieldtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_fieldtype: `%%`(v_fieldtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 +relation free_comptype_is_wf: `%%`(v_comptype : comptype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:490.6-490.20 + rule free_comptype_is_wf_0{v_comptype : comptype, ret_val : free, var_0 : free}: + `%%`(v_comptype, ret_val) + -- wf_comptype: `%`(v_comptype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_comptype: `%%`(v_comptype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 +relation free_subtype_is_wf: `%%`(v_subtype : subtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:491.6-491.19 + rule free_subtype_is_wf_0{v_subtype : subtype, ret_val : free, var_0 : free}: + `%%`(v_subtype, ret_val) + -- wf_subtype: `%`(v_subtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_subtype: `%%`(v_subtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 +relation free_rectype_is_wf: `%%`(v_rectype : rectype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:492.6-492.19 + rule free_rectype_is_wf_0{v_rectype : rectype, ret_val : free, var_0 : free}: + `%%`(v_rectype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_rectype: `%%`(v_rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 +relation free_deftype_is_wf: `%%`(v_deftype : deftype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:520.6-520.19 + rule free_deftype_is_wf_0{v_deftype : deftype, ret_val : free, var_0 : free}: + `%%`(v_deftype, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_deftype: `%%`(v_deftype, var_0) +} + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_tagtype: `%%`(tagtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_tagtype_case_0{v_rectype : rectype, v_n : n, var_0 : free}: + `%%`(_DEF_tagtype(v_rectype, v_n), var_0) + -- fun_free_deftype: `%%`(_DEF_deftype(v_rectype, v_n), var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tagtype_is_wf: `%%`(v_tagtype : tagtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tagtype_is_wf_0{v_tagtype : tagtype, ret_val : free, var_0 : free}: + `%%`(v_tagtype, ret_val) + -- wf_typeuse: `%`(v_tagtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tagtype: `%%`(v_tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_globaltype: `%%`(globaltype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{v_rectype : rectype, v_n : n}(_DEF_tagtype(v_rectype, v_n)) = $free_deftype(_DEF_deftype(v_rectype, v_n)) + rule fun_free_globaltype_case_0{mut_opt : mut?, v_valtype : valtype, var_0 : free}: + `%%`(mk_globaltype_globaltype(mut_opt, v_valtype), var_0) + -- fun_free_valtype: `%%`(v_valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_globaltype(v_globaltype : globaltype) : free +relation free_globaltype_is_wf: `%%`(v_globaltype : globaltype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_globaltype{mut_opt : mut?, v_valtype : valtype}(`%%`_globaltype(mut_opt, v_valtype)) = $free_valtype(v_valtype) + rule free_globaltype_is_wf_0{v_globaltype : globaltype, ret_val : free, var_0 : free}: + `%%`(v_globaltype, ret_val) + -- wf_globaltype: `%`(v_globaltype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_globaltype: `%%`(v_globaltype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_memtype(v_memtype : memtype) : free @@ -2242,38 +3346,118 @@ def $free_memtype(v_memtype : memtype) : free def $free_memtype{v_addrtype : addrtype, v_limits : limits}(`%%PAGE`_memtype(v_addrtype, v_limits)) = $free_addrtype(v_addrtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(v_tabletype : tabletype) : free +relation free_memtype_is_wf: `%%`(v_memtype : memtype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_memtype_is_wf_0{v_memtype : memtype, ret_val : free}: + `%%`(v_memtype, ret_val) + -- wf_memtype: `%`(v_memtype) + -- if (ret_val = $free_memtype(v_memtype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_tabletype: `%%`(tabletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tabletype{v_addrtype : addrtype, v_limits : limits, v_reftype : reftype}(`%%%`_tabletype(v_addrtype, v_limits, v_reftype)) = $free_addrtype(v_addrtype) +++ $free_reftype(v_reftype) + rule fun_free_tabletype_case_0{v_addrtype : addrtype, v_limits : limits, v_reftype : reftype, var_0 : free}: + `%%`(mk_tabletype_tabletype(v_addrtype, v_limits, v_reftype), $free_addrtype(v_addrtype) +++ var_0) + -- fun_free_reftype: `%%`(v_reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_tabletype_is_wf: `%%`(v_tabletype : tabletype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_tabletype_is_wf_0{v_tabletype : tabletype, ret_val : free, var_0 : free}: + `%%`(v_tabletype, ret_val) + -- wf_tabletype: `%`(v_tabletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tabletype: `%%`(v_tabletype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(v_datatype : datatype) : free ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $free_datatype(OK_datatype) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_elemtype(v_elemtype : elemtype) : free +relation free_datatype_is_wf: `%%`(v_datatype : datatype, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule free_datatype_is_wf_0{v_datatype : datatype, ret_val : free}: + `%%`(v_datatype, ret_val) + -- if (ret_val = $free_datatype(v_datatype)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_elemtype: `%%`(elemtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_elemtype_case_0{v_reftype : reftype, var_0 : free}: + `%%`(v_reftype, var_0) + -- fun_free_reftype: `%%`(v_reftype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_elemtype_is_wf: `%%`(v_elemtype : elemtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{v_reftype : reftype}(v_reftype) = $free_reftype(v_reftype) + rule free_elemtype_is_wf_0{v_elemtype : elemtype, ret_val : free, var_0 : free}: + `%%`(v_elemtype, ret_val) + -- wf_reftype: `%`(v_elemtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemtype: `%%`(v_elemtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_externtype(v_externtype : externtype) : free +relation fun_free_externtype: `%%`(externtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_0{v_tagtype : typeuse, var_0 : free}: + `%%`(TAG_externtype(v_tagtype), var_0) + -- fun_free_tagtype: `%%`(v_tagtype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_tagtype : typeuse}(TAG_externtype(v_tagtype)) = $free_tagtype(v_tagtype) + rule fun_free_externtype_case_1{v_globaltype : globaltype, var_0 : free}: + `%%`(GLOBAL_externtype(v_globaltype), var_0) + -- fun_free_globaltype: `%%`(v_globaltype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_externtype_case_2{v_memtype : memtype}: + `%%`(MEM_externtype(v_memtype), $free_memtype(v_memtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_globaltype : globaltype}(GLOBAL_externtype(v_globaltype)) = $free_globaltype(v_globaltype) + rule fun_free_externtype_case_3{v_tabletype : tabletype, var_0 : free}: + `%%`(TABLE_externtype(v_tabletype), var_0) + -- fun_free_tabletype: `%%`(v_tabletype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_memtype : memtype}(MEM_externtype(v_memtype)) = $free_memtype(v_memtype) + rule fun_free_externtype_case_4{v_typeuse : typeuse, var_0 : free}: + `%%`(FUNC_externtype(v_typeuse), var_0) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation free_externtype_is_wf: `%%`(v_externtype : externtype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_tabletype : tabletype}(TABLE_externtype(v_tabletype)) = $free_tabletype(v_tabletype) + rule free_externtype_is_wf_0{v_externtype : externtype, ret_val : free, var_0 : free}: + `%%`(v_externtype, ret_val) + -- wf_externtype: `%`(v_externtype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_externtype: `%%`(v_externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_moduletype: `%%`(moduletype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_typeuse : typeuse}(FUNC_externtype(v_typeuse)) = $free_typeuse(v_typeuse) + rule fun_free_moduletype_case_0{externtype_1_lst : externtype*, externtype_2_lst : externtype*, var_3_lst : free*, var_2 : free, var_1_lst : free*, var_0 : free}: + `%%`(mk_moduletype_moduletype(externtype_1_lst, externtype_2_lst), var_0 +++ var_2) + -- (fun_free_externtype: `%%`(externtype_2, var_3))*{var_3 <- var_3_lst, externtype_2 <- externtype_2_lst} + -- if (|var_3_lst| = |externtype_2_lst|) + -- fun_free_list: `%%`(var_3_lst, var_2) + -- (fun_free_externtype: `%%`(externtype_1, var_1))*{var_1 <- var_1_lst, externtype_1 <- externtype_1_lst} + -- if (|var_1_lst| = |externtype_1_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_moduletype(v_moduletype : moduletype) : free +relation free_moduletype_is_wf: `%%`(v_moduletype : moduletype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_moduletype{externtype_1_lst : externtype*, externtype_2_lst : externtype*}(`%->%`_moduletype(externtype_1_lst, externtype_2_lst)) = $free_list($free_externtype(externtype_1)*{externtype_1 <- externtype_1_lst}) +++ $free_list($free_externtype(externtype_2)*{externtype_2 <- externtype_2_lst}) + rule free_moduletype_is_wf_0{v_moduletype : moduletype, ret_val : free, var_0 : free}: + `%%`(v_moduletype, ret_val) + -- wf_moduletype: `%`(v_moduletype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_moduletype: `%%`(v_moduletype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = @@ -2410,18 +3594,18 @@ def $proj_lit__2(var_x : lit_) : pack_? ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax sz = - | `%`(i : nat) + | mk_sz(i : nat) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_sz_0(x : sz) : (nat) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_sz_0{v_num_0 : nat}(`%`_sz(v_num_0)) = (v_num_0) + def $proj_sz_0{v_num_0 : nat}(mk_sz_sz(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_sz: `%`(sz) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule sz_case_0{i : nat}: - `%`(`%`_sz(i)) + `%`(mk_sz_sz(i)) -- if ((((i = 8) \/ (i = 16)) \/ (i = 32)) \/ (i = 64)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2761,18 +3945,18 @@ def $proj_cvtop___3(var_x : cvtop__) : cvtop__Fnn_1_Fnn_2? ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax dim = - | `%`(i : nat) + | mk_dim(i : nat) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_dim_0(x : dim) : (nat) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_dim_0{v_num_0 : nat}(`%`_dim(v_num_0)) = (v_num_0) + def $proj_dim_0{v_num_0 : nat}(mk_dim_dim(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_dim: `%`(dim) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule dim_case_0{i : nat}: - `%`(`%`_dim(i)) + `%`(mk_dim_dim(i)) -- if (((((i = 1) \/ (i = 2)) \/ (i = 4)) \/ (i = 8)) \/ (i = 16)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2790,50 +3974,58 @@ relation wf_shape: `%`(shape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $fun_dim(v_shape : shape) : dim ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $fun_dim{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, `%`_dim(v_N))) = `%`_dim(v_N) - -- wf_dim: `%`(`%`_dim(v_N)) + def $fun_dim{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, mk_dim_dim(v_N))) = mk_dim_dim(v_N) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation dim_is_wf: `%%`(v_shape : shape, ret_val : dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule dim_is_wf_0{v_shape : shape, ret_val : dim}: + `%%`(v_shape, ret_val) + -- wf_shape: `%`(v_shape) + -- if (ret_val = $fun_dim(v_shape)) + -- wf_dim: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $fun_lanetype(v_shape : shape) : lanetype ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $fun_lanetype{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, `%`_dim(v_N))) = v_Lnn + def $fun_lanetype{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, mk_dim_dim(v_N))) = v_Lnn ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $unpackshape(v_shape : shape) : numtype ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $unpackshape{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, `%`_dim(v_N))) = $lunpack(v_Lnn) + def $unpackshape{v_Lnn : lanetype, v_N : nat}(`%X%`_shape(v_Lnn, mk_dim_dim(v_N))) = $lunpack(v_Lnn) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax ishape = - | `%`(v_shape : shape) + | mk_ishape(v_shape : shape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_ishape_0(x : ishape) : (shape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_ishape_0{v_shape_0 : shape}(`%`_ishape(v_shape_0)) = (v_shape_0) + def $proj_ishape_0{v_shape_0 : shape}(mk_ishape_ishape(v_shape_0)) = (v_shape_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_ishape: `%`(ishape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule ishape_case_0{v_Jnn : Jnn, v_shape : shape}: - `%`(`%`_ishape(v_shape)) + `%`(mk_ishape_ishape(v_shape)) -- wf_shape: `%`(v_shape) -- if ($fun_lanetype(v_shape) = $lanetype_Jnn(v_Jnn)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax bshape = - | `%`(v_shape : shape) + | mk_bshape(v_shape : shape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_bshape_0(x : bshape) : (shape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $proj_bshape_0{v_shape_0 : shape}(`%`_bshape(v_shape_0)) = (v_shape_0) + def $proj_bshape_0{v_shape_0 : shape}(mk_bshape_bshape(v_shape_0)) = (v_shape_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_bshape: `%`(bshape) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule bshape_case_0{v_shape : shape}: - `%`(`%`_bshape(v_shape)) + `%`(mk_bshape_bshape(v_shape)) -- wf_shape: `%`(v_shape) -- if ($fun_lanetype(v_shape) = I8_lanetype) @@ -2907,12 +4099,12 @@ relation wf_vunop_: `%%`(shape, vunop_) rule vunop__case_0{v_shape : shape, v_Jnn : Jnn, v_M : M, var_x : vunop_Jnn_M}: `%%`(v_shape, mk_vunop__0_vunop_(v_Jnn, v_M, var_x)) -- wf_vunop_Jnn_M: `%%%`(v_Jnn, v_M, var_x) - -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vunop__case_1{v_shape : shape, v_Fnn : Fnn, v_M : M, var_x : vunop_Fnn_M}: `%%`(v_shape, mk_vunop__1_vunop_(v_Fnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vunop__0(var_x : vunop_) : vunop_Jnn_M? @@ -3015,12 +4207,12 @@ relation wf_vbinop_: `%%`(shape, vbinop_) rule vbinop__case_0{v_shape : shape, v_Jnn : Jnn, v_M : M, var_x : vbinop_Jnn_M}: `%%`(v_shape, mk_vbinop__0_vbinop_(v_Jnn, v_M, var_x)) -- wf_vbinop_Jnn_M: `%%%`(v_Jnn, v_M, var_x) - -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vbinop__case_1{v_shape : shape, v_Fnn : Fnn, v_M : M, var_x : vbinop_Fnn_M}: `%%`(v_shape, mk_vbinop__1_vbinop_(v_Fnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vbinop__0(var_x : vbinop_) : vbinop_Jnn_M? @@ -3055,12 +4247,12 @@ relation wf_vternop_: `%%`(shape, vternop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_0{v_shape : shape, v_Jnn : Jnn, v_M : M, var_x : vternop_Jnn_M}: `%%`(v_shape, mk_vternop__0_vternop_(v_Jnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vternop__case_1{v_shape : shape, v_Fnn : Fnn, v_M : M, var_x : vternop_Fnn_M}: `%%`(v_shape, mk_vternop__1_vternop_(v_Fnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vternop__0(var_x : vternop_) : vternop_Jnn_M? @@ -3089,7 +4281,7 @@ relation wf_vtestop_: `%%`(shape, vtestop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vtestop__case_0{v_shape : shape, v_Jnn : Jnn, v_M : M, var_x : vtestop_Jnn_M}: `%%`(v_shape, mk_vtestop__0_vtestop_(v_Jnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vtestop__0(var_x : vtestop_) : vtestop_Jnn_M @@ -3155,12 +4347,12 @@ relation wf_vrelop_: `%%`(shape, vrelop_) rule vrelop__case_0{v_shape : shape, v_Jnn : Jnn, v_M : M, var_x : vrelop_Jnn_M}: `%%`(v_shape, mk_vrelop__0_vrelop_(v_Jnn, v_M, var_x)) -- wf_vrelop_Jnn_M: `%%%`(v_Jnn, v_M, var_x) - -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vrelop__case_1{v_shape : shape, v_Fnn : Fnn, v_M : M, var_x : vrelop_Fnn_M}: `%%`(v_shape, mk_vrelop__1_vrelop_(v_Fnn, v_M, var_x)) - -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), `%`_dim(v_M))) + -- if (v_shape = `%X%`_shape($lanetype_Fnn(v_Fnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vrelop__0(var_x : vrelop_) : vrelop_Jnn_M? @@ -3190,7 +4382,7 @@ relation wf_vshiftop_: `%%`(ishape, vshiftop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vshiftop__case_0{v_ishape : ishape, v_Jnn : Jnn, v_M : M, var_x : vshiftop_Jnn_M}: `%%`(v_ishape, mk_vshiftop__0_vshiftop_(v_Jnn, v_M, var_x)) - -- if (v_ishape = `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) + -- if (v_ishape = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vshiftop__0(var_x : vshiftop_) : vshiftop_Jnn_M @@ -3211,7 +4403,7 @@ relation wf_vswizzlop_: `%%`(bshape, vswizzlop_) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vswizzlop__case_0{v_bshape : bshape, v_M : M, var_x : vswizzlop_M}: `%%`(v_bshape, mk_vswizzlop__0_vswizzlop_(v_M, var_x)) - -- if (v_bshape = `%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M)))) + -- if (v_bshape = mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vswizzlop__0(var_x : vswizzlop_) : vswizzlop_M @@ -3239,8 +4431,8 @@ relation wf_vextunop__: `%%%`(ishape, ishape, vextunop__) rule vextunop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextunop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextunop___0_vextunop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextunop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) + -- if (ishape_1 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), mk_dim_dim(M_1)))) + -- if (ishape_2 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), mk_dim_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextunop___0(var_x : vextunop__) : vextunop__Jnn_1_M_1_Jnn_2_M_2 @@ -3280,8 +4472,8 @@ relation wf_vextbinop__: `%%%`(ishape, ishape, vextbinop__) rule vextbinop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextbinop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextbinop___0_vextbinop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextbinop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) + -- if (ishape_1 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), mk_dim_dim(M_1)))) + -- if (ishape_2 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), mk_dim_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextbinop___0(var_x : vextbinop__) : vextbinop__Jnn_1_M_1_Jnn_2_M_2 @@ -3309,8 +4501,8 @@ relation wf_vextternop__: `%%%`(ishape, ishape, vextternop__) rule vextternop___case_0{ishape_1 : ishape, ishape_2 : ishape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vextternop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(ishape_1, ishape_2, mk_vextternop___0_vextternop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vextternop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (ishape_1 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1)))) - -- if (ishape_2 = `%`_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2)))) + -- if (ishape_1 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_1), mk_dim_dim(M_1)))) + -- if (ishape_2 = mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(Jnn_2), mk_dim_dim(M_2)))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vextternop___0(var_x : vextternop__) : vextternop__Jnn_1_M_1_Jnn_2_M_2 @@ -3386,29 +4578,29 @@ relation wf_vcvtop__: `%%%`(shape, shape, vcvtop__) rule vcvtop___case_0{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___0_vcvtop__(Jnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Jnn_2_M_2: `%%%%%`(Jnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), mk_dim_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), mk_dim_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_1{shape_1 : shape, shape_2 : shape, Jnn_1 : Jnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Jnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___1_vcvtop__(Jnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Jnn_1_M_1_Fnn_2_M_2: `%%%%%`(Jnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Jnn(Jnn_1), mk_dim_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), mk_dim_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_2{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Jnn_2 : Jnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Jnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___2_vcvtop__(Fnn_1, M_1, Jnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Jnn_2_M_2: `%%%%%`(Fnn_1, M_1, Jnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), mk_dim_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Jnn(Jnn_2), mk_dim_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule vcvtop___case_3{shape_1 : shape, shape_2 : shape, Fnn_1 : Fnn, M_1 : M, Fnn_2 : Fnn, M_2 : M, var_x : vcvtop__Fnn_1_M_1_Fnn_2_M_2}: `%%%`(shape_1, shape_2, mk_vcvtop___3_vcvtop__(Fnn_1, M_1, Fnn_2, M_2, var_x)) -- wf_vcvtop__Fnn_1_M_1_Fnn_2_M_2: `%%%%%`(Fnn_1, M_1, Fnn_2, M_2, var_x) - -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), `%`_dim(M_1))) - -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), `%`_dim(M_2))) + -- if (shape_1 = `%X%`_shape($lanetype_Fnn(Fnn_1), mk_dim_dim(M_1))) + -- if (shape_2 = `%X%`_shape($lanetype_Fnn(Fnn_2), mk_dim_dim(M_2))) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $proj_vcvtop___0(var_x : vcvtop__) : vcvtop__Jnn_1_M_1_Jnn_2_M_2? @@ -3455,13 +4647,13 @@ relation wf_memarg: `%`(memarg) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax loadop_Inn = - | `%_%`(v_sz : sz, v_sx : sx) + | mk_loadop_Inn(v_sz : sz, v_sx : sx) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_loadop_Inn: `%%`(Inn, loadop_Inn) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule loadop_Inn_case_0{v_Inn : Inn, v_sz : sz, v_sx : sx}: - `%%`(v_Inn, `%_%`_loadop_Inn(v_sz, v_sx)) + `%%`(v_Inn, mk_loadop_Inn_loadop_Inn(v_sz, v_sx)) -- wf_sz: `%`(v_sz) -- if ($proj_sz_0(v_sz).0 < $sizenn($numtype_addrtype(v_Inn))) @@ -3484,13 +4676,13 @@ def $proj_loadop__0(var_x : loadop_) : loadop_Inn ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax storeop_Inn = - | `%`(v_sz : sz) + | mk_storeop_Inn(v_sz : sz) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec relation wf_storeop_Inn: `%%`(Inn, storeop_Inn) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rule storeop_Inn_case_0{v_Inn : Inn, v_sz : sz}: - `%%`(v_Inn, `%`_storeop_Inn(v_sz)) + `%%`(v_Inn, mk_storeop_Inn_storeop_Inn(v_sz)) -- wf_sz: `%`(v_sz) -- if ($proj_sz_0(v_sz).0 < $sizenn($numtype_addrtype(v_Inn))) @@ -3668,14 +4860,14 @@ rec { ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.1-43.19 syntax ref = - | `REF.I31_NUM`(v_u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(v_structaddr : structaddr) - | `REF.ARRAY_ADDR`(v_arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(v_funcaddr : funcaddr) - | `REF.EXN_ADDR`(v_exnaddr : exnaddr) - | `REF.HOST_ADDR`(v_hostaddr : hostaddr) - | `REF.EXTERN`(v_ref : ref) + | REF_I31_NUM(v_u31 : u31) + | REF_NULL_ADDR + | REF_STRUCT_ADDR(v_structaddr : structaddr) + | REF_ARRAY_ADDR(v_arrayaddr : arrayaddr) + | REF_FUNC_ADDR(v_funcaddr : funcaddr) + | REF_EXN_ADDR(v_exnaddr : exnaddr) + | REF_HOST_ADDR(v_hostaddr : hostaddr) + | REF_EXTERN(v_ref : ref) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -3685,60 +4877,60 @@ rec { relation wf_ref: `%`(ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_0{v_u31 : u31}: - `%`(`REF.I31_NUM`_ref(v_u31)) + `%`(REF_I31_NUM_ref(v_u31)) -- wf_uN: `%%`(31, v_u31) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_1: - `%`(`REF.NULL_ADDR`_ref) + `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_2{v_structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_ref(v_structaddr)) + `%`(REF_STRUCT_ADDR_ref(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_3{v_arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_ref(v_arrayaddr)) + `%`(REF_ARRAY_ADDR_ref(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_4{v_funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_ref(v_funcaddr)) + `%`(REF_FUNC_ADDR_ref(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_5{v_exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_ref(v_exnaddr)) + `%`(REF_EXN_ADDR_ref(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_6{v_hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_ref(v_hostaddr)) + `%`(REF_HOST_ADDR_ref(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:35.8-35.11 rule ref_case_7{v_ref : ref}: - `%`(`REF.EXTERN`_ref(v_ref)) + `%`(REF_EXTERN_ref(v_ref)) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax val = | CONST(v_numtype : numtype, num_) | VCONST(v_vectype : vectype, vec_) - | `REF.I31_NUM`(v_u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(v_structaddr : structaddr) - | `REF.ARRAY_ADDR`(v_arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(v_funcaddr : funcaddr) - | `REF.EXN_ADDR`(v_exnaddr : exnaddr) - | `REF.HOST_ADDR`(v_hostaddr : hostaddr) - | `REF.EXTERN`(v_ref : ref) + | REF_I31_NUM(v_u31 : u31) + | REF_NULL_ADDR + | REF_STRUCT_ADDR(v_structaddr : structaddr) + | REF_ARRAY_ADDR(v_arrayaddr : arrayaddr) + | REF_FUNC_ADDR(v_funcaddr : funcaddr) + | REF_EXN_ADDR(v_exnaddr : exnaddr) + | REF_HOST_ADDR(v_hostaddr : hostaddr) + | REF_EXTERN(v_ref : ref) def $val_ref(var_0 : ref) : val - def $val_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_val(x0) - def $val_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_val - def $val_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_val(x0) - def $val_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_val(x0) - def $val_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_val(x0) - def $val_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_val(x0) - def $val_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_val(x0) - def $val_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_val(x0) + def $val_ref{x0 : u31}(REF_I31_NUM_ref(x0)) = REF_I31_NUM_val(x0) + def $val_ref(REF_NULL_ADDR_ref) = REF_NULL_ADDR_val + def $val_ref{x0 : structaddr}(REF_STRUCT_ADDR_ref(x0)) = REF_STRUCT_ADDR_val(x0) + def $val_ref{x0 : arrayaddr}(REF_ARRAY_ADDR_ref(x0)) = REF_ARRAY_ADDR_val(x0) + def $val_ref{x0 : funcaddr}(REF_FUNC_ADDR_ref(x0)) = REF_FUNC_ADDR_val(x0) + def $val_ref{x0 : exnaddr}(REF_EXN_ADDR_ref(x0)) = REF_EXN_ADDR_val(x0) + def $val_ref{x0 : hostaddr}(REF_HOST_ADDR_ref(x0)) = REF_HOST_ADDR_val(x0) + def $val_ref{x0 : ref}(REF_EXTERN_ref(x0)) = REF_EXTERN_val(x0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_val: `%`(val) @@ -3754,36 +4946,36 @@ relation wf_val: `%`(val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_2{v_u31 : u31}: - `%`(`REF.I31_NUM`_val(v_u31)) + `%`(REF_I31_NUM_val(v_u31)) -- wf_uN: `%%`(31, v_u31) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_3: - `%`(`REF.NULL_ADDR`_val) + `%`(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_4{v_structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_val(v_structaddr)) + `%`(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_5{v_arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + `%`(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_6{v_funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_val(v_funcaddr)) + `%`(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_7{v_exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_val(v_exnaddr)) + `%`(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_8{v_hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_val(v_hostaddr)) + `%`(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule val_case_9{v_ref : ref}: - `%`(`REF.EXTERN`_val(v_ref)) + `%`(REF_EXTERN_val(v_ref)) -- wf_ref: `%`(v_ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -3830,58 +5022,58 @@ syntax instr = | THROW(v_tagidx : tagidx) | THROW_REF | TRY_TABLE(v_blocktype : blocktype, list(syntax catch), instr_lst : instr*) - | `LOCAL.GET`(v_localidx : localidx) - | `LOCAL.SET`(v_localidx : localidx) - | `LOCAL.TEE`(v_localidx : localidx) - | `GLOBAL.GET`(v_globalidx : globalidx) - | `GLOBAL.SET`(v_globalidx : globalidx) - | `TABLE.GET`(v_tableidx : tableidx) - | `TABLE.SET`(v_tableidx : tableidx) - | `TABLE.SIZE`(v_tableidx : tableidx) - | `TABLE.GROW`(v_tableidx : tableidx) - | `TABLE.FILL`(v_tableidx : tableidx) - | `TABLE.COPY`(v_tableidx : tableidx, v_tableidx : tableidx) - | `TABLE.INIT`(v_tableidx : tableidx, v_elemidx : elemidx) - | `ELEM.DROP`(v_elemidx : elemidx) + | LOCAL_GET(v_localidx : localidx) + | LOCAL_SET(v_localidx : localidx) + | LOCAL_TEE(v_localidx : localidx) + | GLOBAL_GET(v_globalidx : globalidx) + | GLOBAL_SET(v_globalidx : globalidx) + | TABLE_GET(v_tableidx : tableidx) + | TABLE_SET(v_tableidx : tableidx) + | TABLE_SIZE(v_tableidx : tableidx) + | TABLE_GROW(v_tableidx : tableidx) + | TABLE_FILL(v_tableidx : tableidx) + | TABLE_COPY(v_tableidx : tableidx, v_tableidx : tableidx) + | TABLE_INIT(v_tableidx : tableidx, v_elemidx : elemidx) + | ELEM_DROP(v_elemidx : elemidx) | LOAD(v_numtype : numtype, loadop_?, v_memidx : memidx, v_memarg : memarg) | STORE(v_numtype : numtype, storeop_?, v_memidx : memidx, v_memarg : memarg) | VLOAD(v_vectype : vectype, vloadop_?, v_memidx : memidx, v_memarg : memarg) | VLOAD_LANE(v_vectype : vectype, v_sz : sz, v_memidx : memidx, v_memarg : memarg, v_laneidx : laneidx) | VSTORE(v_vectype : vectype, v_memidx : memidx, v_memarg : memarg) | VSTORE_LANE(v_vectype : vectype, v_sz : sz, v_memidx : memidx, v_memarg : memarg, v_laneidx : laneidx) - | `MEMORY.SIZE`(v_memidx : memidx) - | `MEMORY.GROW`(v_memidx : memidx) - | `MEMORY.FILL`(v_memidx : memidx) - | `MEMORY.COPY`(v_memidx : memidx, v_memidx : memidx) - | `MEMORY.INIT`(v_memidx : memidx, v_dataidx : dataidx) - | `DATA.DROP`(v_dataidx : dataidx) - | `REF.NULL`(v_heaptype : heaptype) - | `REF.IS_NULL` - | `REF.AS_NON_NULL` - | `REF.EQ` - | `REF.TEST`(v_reftype : reftype) - | `REF.CAST`(v_reftype : reftype) - | `REF.FUNC`(v_funcidx : funcidx) - | `REF.I31` - | `I31.GET`(v_sx : sx) - | `STRUCT.NEW`(v_typeidx : typeidx) - | `STRUCT.NEW_DEFAULT`(v_typeidx : typeidx) - | `STRUCT.GET`(sx_opt : sx?, v_typeidx : typeidx, v_fieldidx : fieldidx) - | `STRUCT.SET`(v_typeidx : typeidx, v_fieldidx : fieldidx) - | `ARRAY.NEW`(v_typeidx : typeidx) - | `ARRAY.NEW_DEFAULT`(v_typeidx : typeidx) - | `ARRAY.NEW_FIXED`(v_typeidx : typeidx, v_u32 : u32) - | `ARRAY.NEW_DATA`(v_typeidx : typeidx, v_dataidx : dataidx) - | `ARRAY.NEW_ELEM`(v_typeidx : typeidx, v_elemidx : elemidx) - | `ARRAY.GET`(sx_opt : sx?, v_typeidx : typeidx) - | `ARRAY.SET`(v_typeidx : typeidx) - | `ARRAY.LEN` - | `ARRAY.FILL`(v_typeidx : typeidx) - | `ARRAY.COPY`(v_typeidx : typeidx, v_typeidx : typeidx) - | `ARRAY.INIT_DATA`(v_typeidx : typeidx, v_dataidx : dataidx) - | `ARRAY.INIT_ELEM`(v_typeidx : typeidx, v_elemidx : elemidx) - | `EXTERN.CONVERT_ANY` - | `ANY.CONVERT_EXTERN` + | MEMORY_SIZE(v_memidx : memidx) + | MEMORY_GROW(v_memidx : memidx) + | MEMORY_FILL(v_memidx : memidx) + | MEMORY_COPY(v_memidx : memidx, v_memidx : memidx) + | MEMORY_INIT(v_memidx : memidx, v_dataidx : dataidx) + | DATA_DROP(v_dataidx : dataidx) + | REF_NULL(v_heaptype : heaptype) + | REF_IS_NULL + | REF_AS_NON_NULL + | REF_EQ + | REF_TEST(v_reftype : reftype) + | REF_CAST(v_reftype : reftype) + | REF_FUNC(v_funcidx : funcidx) + | REF_I31 + | I31_GET(v_sx : sx) + | STRUCT_NEW(v_typeidx : typeidx) + | STRUCT_NEW_DEFAULT(v_typeidx : typeidx) + | STRUCT_GET(sx_opt : sx?, v_typeidx : typeidx, v_fieldidx : fieldidx) + | STRUCT_SET(v_typeidx : typeidx, v_fieldidx : fieldidx) + | ARRAY_NEW(v_typeidx : typeidx) + | ARRAY_NEW_DEFAULT(v_typeidx : typeidx) + | ARRAY_NEW_FIXED(v_typeidx : typeidx, v_u32 : u32) + | ARRAY_NEW_DATA(v_typeidx : typeidx, v_dataidx : dataidx) + | ARRAY_NEW_ELEM(v_typeidx : typeidx, v_elemidx : elemidx) + | ARRAY_GET(sx_opt : sx?, v_typeidx : typeidx) + | ARRAY_SET(v_typeidx : typeidx) + | ARRAY_LEN + | ARRAY_FILL(v_typeidx : typeidx) + | ARRAY_COPY(v_typeidx : typeidx, v_typeidx : typeidx) + | ARRAY_INIT_DATA(v_typeidx : typeidx, v_dataidx : dataidx) + | ARRAY_INIT_ELEM(v_typeidx : typeidx, v_elemidx : elemidx) + | EXTERN_CONVERT_ANY + | ANY_CONVERT_EXTERN | CONST(v_numtype : numtype, num_) | UNOP(v_numtype : numtype, unop_) | BINOP(v_numtype : numtype, binop_) @@ -3910,14 +5102,14 @@ syntax instr = | VSPLAT(v_shape : shape) | VEXTRACT_LANE(v_shape : shape, sx_opt : sx?, v_laneidx : laneidx) | VREPLACE_LANE(v_shape : shape, v_laneidx : laneidx) - | `REF.I31_NUM`(v_u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(v_structaddr : structaddr) - | `REF.ARRAY_ADDR`(v_arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(v_funcaddr : funcaddr) - | `REF.EXN_ADDR`(v_exnaddr : exnaddr) - | `REF.HOST_ADDR`(v_hostaddr : hostaddr) - | `REF.EXTERN`(v_ref : ref) + | REF_I31_NUM(v_u31 : u31) + | REF_NULL_ADDR + | REF_STRUCT_ADDR(v_structaddr : structaddr) + | REF_ARRAY_ADDR(v_arrayaddr : arrayaddr) + | REF_FUNC_ADDR(v_funcaddr : funcaddr) + | REF_EXN_ADDR(v_exnaddr : exnaddr) + | REF_HOST_ADDR(v_hostaddr : hostaddr) + | REF_EXTERN(v_ref : ref) | `LABEL_%{%}%`(v_n : n, instr_lst : instr*, instr_lst : instr*) | `FRAME_%{%}%`(v_n : n, v_frame : frame, instr_lst : instr*) | `HANDLER_%{%}%`(v_n : n, catch_lst : catch*, instr_lst : instr*) @@ -3925,26 +5117,26 @@ syntax instr = } def $instr_ref(var_0 : ref) : instr - def $instr_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_instr(x0) - def $instr_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_instr - def $instr_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_instr(x0) - def $instr_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_instr(x0) - def $instr_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_instr(x0) - def $instr_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_instr(x0) - def $instr_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_instr(x0) - def $instr_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_instr(x0) + def $instr_ref{x0 : u31}(REF_I31_NUM_ref(x0)) = REF_I31_NUM_instr(x0) + def $instr_ref(REF_NULL_ADDR_ref) = REF_NULL_ADDR_instr + def $instr_ref{x0 : structaddr}(REF_STRUCT_ADDR_ref(x0)) = REF_STRUCT_ADDR_instr(x0) + def $instr_ref{x0 : arrayaddr}(REF_ARRAY_ADDR_ref(x0)) = REF_ARRAY_ADDR_instr(x0) + def $instr_ref{x0 : funcaddr}(REF_FUNC_ADDR_ref(x0)) = REF_FUNC_ADDR_instr(x0) + def $instr_ref{x0 : exnaddr}(REF_EXN_ADDR_ref(x0)) = REF_EXN_ADDR_instr(x0) + def $instr_ref{x0 : hostaddr}(REF_HOST_ADDR_ref(x0)) = REF_HOST_ADDR_instr(x0) + def $instr_ref{x0 : ref}(REF_EXTERN_ref(x0)) = REF_EXTERN_instr(x0) def $instr_val(var_0 : val) : instr def $instr_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_instr(x0, x1) def $instr_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_instr(x0, x1) - def $instr_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_instr(x0) - def $instr_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_instr - def $instr_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_instr(x0) - def $instr_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_instr(x0) - def $instr_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_instr(x0) - def $instr_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_instr(x0) - def $instr_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_instr(x0) - def $instr_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_instr(x0) + def $instr_val{x0 : u31}(REF_I31_NUM_val(x0)) = REF_I31_NUM_instr(x0) + def $instr_val(REF_NULL_ADDR_val) = REF_NULL_ADDR_instr + def $instr_val{x0 : structaddr}(REF_STRUCT_ADDR_val(x0)) = REF_STRUCT_ADDR_instr(x0) + def $instr_val{x0 : arrayaddr}(REF_ARRAY_ADDR_val(x0)) = REF_ARRAY_ADDR_instr(x0) + def $instr_val{x0 : funcaddr}(REF_FUNC_ADDR_val(x0)) = REF_FUNC_ADDR_instr(x0) + def $instr_val{x0 : exnaddr}(REF_EXN_ADDR_val(x0)) = REF_EXN_ADDR_instr(x0) + def $instr_val{x0 : hostaddr}(REF_HOST_ADDR_val(x0)) = REF_HOST_ADDR_instr(x0) + def $instr_val{x0 : ref}(REF_EXTERN_val(x0)) = REF_EXTERN_instr(x0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -4080,69 +5272,69 @@ relation wf_instr: `%`(instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_24{v_localidx : localidx}: - `%`(`LOCAL.GET`_instr(v_localidx)) + `%`(LOCAL_GET_instr(v_localidx)) -- wf_uN: `%%`(32, v_localidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_25{v_localidx : localidx}: - `%`(`LOCAL.SET`_instr(v_localidx)) + `%`(LOCAL_SET_instr(v_localidx)) -- wf_uN: `%%`(32, v_localidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_26{v_localidx : localidx}: - `%`(`LOCAL.TEE`_instr(v_localidx)) + `%`(LOCAL_TEE_instr(v_localidx)) -- wf_uN: `%%`(32, v_localidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_27{v_globalidx : globalidx}: - `%`(`GLOBAL.GET`_instr(v_globalidx)) + `%`(GLOBAL_GET_instr(v_globalidx)) -- wf_uN: `%%`(32, v_globalidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_28{v_globalidx : globalidx}: - `%`(`GLOBAL.SET`_instr(v_globalidx)) + `%`(GLOBAL_SET_instr(v_globalidx)) -- wf_uN: `%%`(32, v_globalidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_29{v_tableidx : tableidx}: - `%`(`TABLE.GET`_instr(v_tableidx)) + `%`(TABLE_GET_instr(v_tableidx)) -- wf_uN: `%%`(32, v_tableidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_30{v_tableidx : tableidx}: - `%`(`TABLE.SET`_instr(v_tableidx)) + `%`(TABLE_SET_instr(v_tableidx)) -- wf_uN: `%%`(32, v_tableidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_31{v_tableidx : tableidx}: - `%`(`TABLE.SIZE`_instr(v_tableidx)) + `%`(TABLE_SIZE_instr(v_tableidx)) -- wf_uN: `%%`(32, v_tableidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_32{v_tableidx : tableidx}: - `%`(`TABLE.GROW`_instr(v_tableidx)) + `%`(TABLE_GROW_instr(v_tableidx)) -- wf_uN: `%%`(32, v_tableidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_33{v_tableidx : tableidx}: - `%`(`TABLE.FILL`_instr(v_tableidx)) + `%`(TABLE_FILL_instr(v_tableidx)) -- wf_uN: `%%`(32, v_tableidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_34{v_tableidx : tableidx, tableidx_0 : tableidx}: - `%`(`TABLE.COPY`_instr(v_tableidx, tableidx_0)) + `%`(TABLE_COPY_instr(v_tableidx, tableidx_0)) -- wf_uN: `%%`(32, v_tableidx) -- wf_uN: `%%`(32, tableidx_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_35{v_tableidx : tableidx, v_elemidx : elemidx}: - `%`(`TABLE.INIT`_instr(v_tableidx, v_elemidx)) + `%`(TABLE_INIT_instr(v_tableidx, v_elemidx)) -- wf_uN: `%%`(32, v_tableidx) -- wf_uN: `%%`(32, v_elemidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_36{v_elemidx : elemidx}: - `%`(`ELEM.DROP`_instr(v_elemidx)) + `%`(ELEM_DROP_instr(v_elemidx)) -- wf_uN: `%%`(32, v_elemidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 @@ -4190,170 +5382,170 @@ relation wf_instr: `%`(instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_43{v_memidx : memidx}: - `%`(`MEMORY.SIZE`_instr(v_memidx)) + `%`(MEMORY_SIZE_instr(v_memidx)) -- wf_uN: `%%`(32, v_memidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_44{v_memidx : memidx}: - `%`(`MEMORY.GROW`_instr(v_memidx)) + `%`(MEMORY_GROW_instr(v_memidx)) -- wf_uN: `%%`(32, v_memidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_45{v_memidx : memidx}: - `%`(`MEMORY.FILL`_instr(v_memidx)) + `%`(MEMORY_FILL_instr(v_memidx)) -- wf_uN: `%%`(32, v_memidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_46{v_memidx : memidx, memidx_0 : memidx}: - `%`(`MEMORY.COPY`_instr(v_memidx, memidx_0)) + `%`(MEMORY_COPY_instr(v_memidx, memidx_0)) -- wf_uN: `%%`(32, v_memidx) -- wf_uN: `%%`(32, memidx_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_47{v_memidx : memidx, v_dataidx : dataidx}: - `%`(`MEMORY.INIT`_instr(v_memidx, v_dataidx)) + `%`(MEMORY_INIT_instr(v_memidx, v_dataidx)) -- wf_uN: `%%`(32, v_memidx) -- wf_uN: `%%`(32, v_dataidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_48{v_dataidx : dataidx}: - `%`(`DATA.DROP`_instr(v_dataidx)) + `%`(DATA_DROP_instr(v_dataidx)) -- wf_uN: `%%`(32, v_dataidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_49{v_heaptype : heaptype}: - `%`(`REF.NULL`_instr(v_heaptype)) + `%`(REF_NULL_instr(v_heaptype)) -- wf_heaptype: `%`(v_heaptype) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_50: - `%`(`REF.IS_NULL`_instr) + `%`(REF_IS_NULL_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_51: - `%`(`REF.AS_NON_NULL`_instr) + `%`(REF_AS_NON_NULL_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_52: - `%`(`REF.EQ`_instr) + `%`(REF_EQ_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_53{v_reftype : reftype}: - `%`(`REF.TEST`_instr(v_reftype)) + `%`(REF_TEST_instr(v_reftype)) -- wf_reftype: `%`(v_reftype) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_54{v_reftype : reftype}: - `%`(`REF.CAST`_instr(v_reftype)) + `%`(REF_CAST_instr(v_reftype)) -- wf_reftype: `%`(v_reftype) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_55{v_funcidx : funcidx}: - `%`(`REF.FUNC`_instr(v_funcidx)) + `%`(REF_FUNC_instr(v_funcidx)) -- wf_uN: `%%`(32, v_funcidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_56: - `%`(`REF.I31`_instr) + `%`(REF_I31_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_57{v_sx : sx}: - `%`(`I31.GET`_instr(v_sx)) + `%`(I31_GET_instr(v_sx)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_58{v_typeidx : typeidx}: - `%`(`STRUCT.NEW`_instr(v_typeidx)) + `%`(STRUCT_NEW_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_59{v_typeidx : typeidx}: - `%`(`STRUCT.NEW_DEFAULT`_instr(v_typeidx)) + `%`(STRUCT_NEW_DEFAULT_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_60{sx_opt : sx?, v_typeidx : typeidx, v_fieldidx : fieldidx}: - `%`(`STRUCT.GET`_instr(sx_opt, v_typeidx, v_fieldidx)) + `%`(STRUCT_GET_instr(sx_opt, v_typeidx, v_fieldidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_fieldidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_61{v_typeidx : typeidx, v_fieldidx : fieldidx}: - `%`(`STRUCT.SET`_instr(v_typeidx, v_fieldidx)) + `%`(STRUCT_SET_instr(v_typeidx, v_fieldidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_fieldidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_62{v_typeidx : typeidx}: - `%`(`ARRAY.NEW`_instr(v_typeidx)) + `%`(ARRAY_NEW_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_63{v_typeidx : typeidx}: - `%`(`ARRAY.NEW_DEFAULT`_instr(v_typeidx)) + `%`(ARRAY_NEW_DEFAULT_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_64{v_typeidx : typeidx, v_u32 : u32}: - `%`(`ARRAY.NEW_FIXED`_instr(v_typeidx, v_u32)) + `%`(ARRAY_NEW_FIXED_instr(v_typeidx, v_u32)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_u32) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_65{v_typeidx : typeidx, v_dataidx : dataidx}: - `%`(`ARRAY.NEW_DATA`_instr(v_typeidx, v_dataidx)) + `%`(ARRAY_NEW_DATA_instr(v_typeidx, v_dataidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_dataidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_66{v_typeidx : typeidx, v_elemidx : elemidx}: - `%`(`ARRAY.NEW_ELEM`_instr(v_typeidx, v_elemidx)) + `%`(ARRAY_NEW_ELEM_instr(v_typeidx, v_elemidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_elemidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_67{sx_opt : sx?, v_typeidx : typeidx}: - `%`(`ARRAY.GET`_instr(sx_opt, v_typeidx)) + `%`(ARRAY_GET_instr(sx_opt, v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_68{v_typeidx : typeidx}: - `%`(`ARRAY.SET`_instr(v_typeidx)) + `%`(ARRAY_SET_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_69: - `%`(`ARRAY.LEN`_instr) + `%`(ARRAY_LEN_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_70{v_typeidx : typeidx}: - `%`(`ARRAY.FILL`_instr(v_typeidx)) + `%`(ARRAY_FILL_instr(v_typeidx)) -- wf_uN: `%%`(32, v_typeidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_71{v_typeidx : typeidx, typeidx_0 : typeidx}: - `%`(`ARRAY.COPY`_instr(v_typeidx, typeidx_0)) + `%`(ARRAY_COPY_instr(v_typeidx, typeidx_0)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, typeidx_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_72{v_typeidx : typeidx, v_dataidx : dataidx}: - `%`(`ARRAY.INIT_DATA`_instr(v_typeidx, v_dataidx)) + `%`(ARRAY_INIT_DATA_instr(v_typeidx, v_dataidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_dataidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_73{v_typeidx : typeidx, v_elemidx : elemidx}: - `%`(`ARRAY.INIT_ELEM`_instr(v_typeidx, v_elemidx)) + `%`(ARRAY_INIT_ELEM_instr(v_typeidx, v_elemidx)) -- wf_uN: `%%`(32, v_typeidx) -- wf_uN: `%%`(32, v_elemidx) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_74: - `%`(`EXTERN.CONVERT_ANY`_instr) + `%`(EXTERN_CONVERT_ANY_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_75: - `%`(`ANY.CONVERT_EXTERN`_instr) + `%`(ANY_CONVERT_EXTERN_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_76{v_numtype : numtype, var_0 : num_}: @@ -4458,7 +5650,7 @@ relation wf_instr: `%`(instr) `%`(VSHUFFLE_instr(v_bshape, laneidx_lst)) -- wf_bshape: `%`(v_bshape) -- (wf_uN: `%%`(8, v_laneidx))*{v_laneidx <- laneidx_lst} - -- if (`%`_dim(|laneidx_lst|) = $fun_dim($proj_bshape_0(v_bshape).0)) + -- if (mk_dim_dim(|laneidx_lst|) = $fun_dim($proj_bshape_0(v_bshape).0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_96{ishape_1 : ishape, ishape_2 : ishape, var_0 : vextunop__}: @@ -4505,8 +5697,8 @@ relation wf_instr: `%`(instr) `%`(VEXTRACT_LANE_instr(v_shape, sx_opt, v_laneidx)) -- wf_shape: `%`(v_shape) -- wf_uN: `%%`(8, v_laneidx) - -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) -- if ((sx_opt = ?()) <=> ($fun_lanetype(v_shape) <- [I32_lanetype I64_lanetype F32_lanetype F64_lanetype])) + -- if (|[I32_lanetype I64_lanetype F32_lanetype F64_lanetype]| > 0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_103{v_shape : shape, v_laneidx : laneidx}: @@ -4516,36 +5708,36 @@ relation wf_instr: `%`(instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_104{v_u31 : u31}: - `%`(`REF.I31_NUM`_instr(v_u31)) + `%`(REF_I31_NUM_instr(v_u31)) -- wf_uN: `%%`(31, v_u31) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_105: - `%`(`REF.NULL_ADDR`_instr) + `%`(REF_NULL_ADDR_instr) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_106{v_structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_instr(v_structaddr)) + `%`(REF_STRUCT_ADDR_instr(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_107{v_arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_instr(v_arrayaddr)) + `%`(REF_ARRAY_ADDR_instr(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_108{v_funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_instr(v_funcaddr)) + `%`(REF_FUNC_ADDR_instr(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_109{v_exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_instr(v_exnaddr)) + `%`(REF_EXN_ADDR_instr(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_110{v_hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_instr(v_hostaddr)) + `%`(REF_HOST_ADDR_instr(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 rule instr_case_111{v_ref : ref}: - `%`(`REF.EXTERN`_instr(v_ref)) + `%`(REF_EXTERN_instr(v_ref)) -- wf_ref: `%`(v_ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 @@ -4577,26 +5769,37 @@ syntax expr = instr* ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $memarg0 : memarg ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} - -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + def $memarg0 = {ALIGN mk_uN_u32(0), OFFSET mk_uN_u64(0)} + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation memarg0_is_wf: `%`(ret_val : memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule memarg0_is_wf_0{ret_val : memarg}: + `%`(ret_val) + -- if (ret_val = $memarg0) + -- wf_memarg: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const(v_consttype : consttype, v_lit_ : lit_) : instr ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I32_consttype, mk_lit__0_lit_(I32_numtype, c)) = CONST_instr(I32_numtype, c) - -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(I64_consttype, mk_lit__0_lit_(I64_numtype, c)) = CONST_instr(I64_numtype, c) - -- wf_instr: `%`(CONST_instr(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F32_consttype, mk_lit__0_lit_(F32_numtype, c)) = CONST_instr(F32_numtype, c) - -- wf_instr: `%`(CONST_instr(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : num_}(F64_consttype, mk_lit__0_lit_(F64_numtype, c)) = CONST_instr(F64_numtype, c) - -- wf_instr: `%`(CONST_instr(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $const{c : uN}(V128_consttype, mk_lit__1_lit_(V128_vectype, c)) = VCONST_instr(V128_vectype, c) - -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation const_is_wf: `%%%`(v_consttype : consttype, v_lit_ : lit_, ret_val : instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule const_is_wf_0{v_consttype : consttype, v_lit_ : lit_, ret_val : instr}: + `%%%`(v_consttype, v_lit_, ret_val) + -- wf_lit_: `%%`($storagetype_consttype(v_consttype), v_lit_) + -- if (ret_val = $const(v_consttype, v_lit_)) + -- wf_instr: `%`(ret_val) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_shape(v_shape : shape) : free @@ -4604,11 +5807,35 @@ def $free_shape(v_shape : shape) : free def $free_shape{v_lanetype : lanetype, v_dim : dim}(`%X%`_shape(v_lanetype, v_dim)) = $free_lanetype(v_lanetype) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(v_blocktype : blocktype) : free +relation free_shape_is_wf: `%%`(v_shape : shape, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_shape_is_wf_0{v_shape : shape, ret_val : free}: + `%%`(v_shape, ret_val) + -- wf_shape: `%`(v_shape) + -- if (ret_val = $free_shape(v_shape)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_free_blocktype: `%%`(blocktype, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_0{valtype_opt : valtype?, var_0_opt : free?}: + `%%`(_RESULT_blocktype(valtype_opt), $free_opt(var_0_opt)) + -- (fun_free_valtype: `%%`(v_valtype, var_0))?{var_0 <- var_0_opt, v_valtype <- valtype_opt} + -- if ((var_0_opt = ?()) <=> (valtype_opt = ?())) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{valtype_opt : valtype?}(_RESULT_blocktype(valtype_opt)) = $free_opt($free_valtype(v_valtype)?{v_valtype <- valtype_opt}) + rule fun_free_blocktype_case_1{v_typeidx : uN}: + `%%`(_IDX_blocktype(v_typeidx), $free_typeidx(v_typeidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_blocktype_is_wf: `%%`(v_blocktype : blocktype, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{v_typeidx : uN}(_IDX_blocktype(v_typeidx)) = $free_typeidx(v_typeidx) + rule free_blocktype_is_wf_0{v_blocktype : blocktype, ret_val : free, var_0 : free}: + `%%`(v_blocktype, ret_val) + -- wf_blocktype: `%`(v_blocktype) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_blocktype: `%%`(v_blocktype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch(v_catch : catch) : free @@ -4621,258 +5848,539 @@ def $free_catch(v_catch : catch) : free ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec def $free_catch{v_labelidx : uN}(CATCH_ALL_REF_catch(v_labelidx)) = $free_labelidx(v_labelidx) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_catch_is_wf: `%%`(v_catch : catch, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule free_catch_is_wf_0{v_catch : catch, ret_val : free}: + `%%`(v_catch, ret_val) + -- wf_catch: `%`(v_catch) + -- if (ret_val = $free_catch(v_catch)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +rec { + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 +relation fun_shift_labelidxs: `%%`(labelidx*, labelidx*) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_1{labelidx'_lst : labelidx*, var_0 : labelidx*}: + `%%`([mk_uN_labelidx(0)] ++ labelidx'_lst, var_0) + -- fun_shift_labelidxs: `%%`(labelidx'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.6-584.22 + rule fun_shift_labelidxs_case_2{v_labelidx : uN, labelidx'_lst : labelidx*, var_0 : labelidx*}: + `%%`([v_labelidx] ++ labelidx'_lst, [mk_uN_labelidx(((($proj_uN_0(v_labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) + -- fun_shift_labelidxs: `%%`(labelidx'_lst, var_0) +} + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:584.1-584.44 -def $shift_labelidxs(var_0 : labelidx*) : labelidx* - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:585.1-585.32 - def $shift_labelidxs([]) = [] - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:586.1-586.66 - def $shift_labelidxs{labelidx'_lst : labelidx*}([`%`_labelidx(0)] ++ labelidx'_lst) = $shift_labelidxs(labelidx'_lst) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:587.1-587.91 - def $shift_labelidxs{v_labelidx : uN, labelidx'_lst : labelidx*}([v_labelidx] ++ labelidx'_lst) = [`%`_labelidx(((($proj_uN_0(v_labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ $shift_labelidxs(labelidx'_lst) - -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(v_labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation fun_free_instr: `%%`(instr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_0: + `%%`(NOP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_1: + `%%`(UNREACHABLE_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_2: + `%%`(DROP_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{valtype_lst_opt : valtype*?, var_1_lst_opt : free*?, var_0_opt : free?}: + `%%`(SELECT_instr(valtype_lst_opt), $free_opt(var_0_opt)) + -- (fun_free_valtype: `%%`(v_valtype, var_1))*{var_1 <- var_1_lst, v_valtype <- valtype_lst}?{var_1_lst <- var_1_lst_opt, valtype_lst <- valtype_lst_opt} + -- if ((var_1_lst_opt = ?()) <=> (valtype_lst_opt = ?())) + -- (if (|var_1_lst| = |valtype_lst|))?{var_1_lst <- var_1_lst_opt, valtype_lst <- valtype_lst_opt} + -- (fun_free_list: `%%`(var_1_lst, var_0))?{var_1_lst <- var_1_lst_opt, var_0 <- var_0_opt} + -- if ((var_1_lst_opt = ?()) <=> (var_0_opt = ?())) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_4{v_blocktype : blocktype, instr_lst : instr*, var_1 : free, var_0 : free}: + `%%`(BLOCK_instr(v_blocktype, instr_lst), var_0 +++ var_1) + -- fun_free_block: `%%`(instr_lst, var_1) + -- fun_free_blocktype: `%%`(v_blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_5{v_blocktype : blocktype, instr_lst : instr*, var_1 : free, var_0 : free}: + `%%`(LOOP_instr(v_blocktype, instr_lst), var_0 +++ var_1) + -- fun_free_block: `%%`(instr_lst, var_1) + -- fun_free_blocktype: `%%`(v_blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_6{v_blocktype : blocktype, instr_1_lst : instr*, instr_2_lst : instr*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(`IF%%ELSE%`_instr(v_blocktype, instr_1_lst, instr_2_lst), var_0 +++ var_1 +++ var_2) + -- fun_free_block: `%%`(instr_2_lst, var_2) + -- fun_free_block: `%%`(instr_1_lst, var_1) + -- fun_free_blocktype: `%%`(v_blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_7{v_labelidx : uN}: + `%%`(BR_instr(v_labelidx), $free_labelidx(v_labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{v_labelidx : uN}: + `%%`(BR_IF_instr(v_labelidx), $free_labelidx(v_labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{labelidx_lst : labelidx*, labelidx' : uN, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx_lst, labelidx'), var_0 +++ $free_labelidx(labelidx')) + -- fun_free_list: `%%`($free_labelidx(v_labelidx)*{v_labelidx <- labelidx_lst}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{v_labelidx : uN}: + `%%`(BR_ON_NULL_instr(v_labelidx), $free_labelidx(v_labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{v_labelidx : uN}: + `%%`(BR_ON_NON_NULL_instr(v_labelidx), $free_labelidx(v_labelidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_12{v_labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(v_labelidx, reftype_1, reftype_2), $free_labelidx(v_labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_13{v_labelidx : uN, reftype_1 : reftype, reftype_2 : reftype, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(v_labelidx, reftype_1, reftype_2), $free_labelidx(v_labelidx) +++ var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype_2, var_1) + -- fun_free_reftype: `%%`(reftype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{v_funcidx : uN}: + `%%`(CALL_instr(v_funcidx), $free_funcidx(v_funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_15{v_typeuse : typeuse, var_0 : free}: + `%%`(CALL_REF_instr(v_typeuse), var_0) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_16{v_tableidx : uN, v_typeuse : typeuse, var_0 : free}: + `%%`(CALL_INDIRECT_instr(v_tableidx, v_typeuse), $free_tableidx(v_tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_17: + `%%`(RETURN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{v_funcidx : uN}: + `%%`(RETURN_CALL_instr(v_funcidx), $free_funcidx(v_funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_19{v_typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_REF_instr(v_typeuse), var_0) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_20{v_tableidx : uN, v_typeuse : typeuse, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(v_tableidx, v_typeuse), $free_tableidx(v_tableidx) +++ var_0) + -- fun_free_typeuse: `%%`(v_typeuse, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{v_tagidx : uN}: + `%%`(THROW_instr(v_tagidx), $free_tagidx(v_tagidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_22: + `%%`(THROW_REF_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_23{v_blocktype : blocktype, catch_lst : catch*, instr_lst : instr*, var_3_lst : free*, var_2 : free, var_1 : free, var_0 : free}: + `%%`(TRY_TABLE_instr(v_blocktype, mk_list_list(catch_lst), instr_lst), var_0 +++ var_1 +++ var_2) + -- (fun_free_instr: `%%`(v_instr, var_3))*{var_3 <- var_3_lst, v_instr <- instr_lst} + -- if (|var_3_lst| = |instr_lst|) + -- fun_free_list: `%%`(var_3_lst, var_2) + -- fun_free_list: `%%`($free_catch(v_catch)*{v_catch <- catch_lst}, var_1) + -- fun_free_blocktype: `%%`(v_blocktype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_24{v_numtype : numtype, numlit : num_}: + `%%`(CONST_instr(v_numtype, numlit), $free_numtype(v_numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{v_numtype : numtype, unop : unop_}: + `%%`(UNOP_instr(v_numtype, unop), $free_numtype(v_numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{v_numtype : numtype, binop : binop_}: + `%%`(BINOP_instr(v_numtype, binop), $free_numtype(v_numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{v_numtype : numtype, testop : testop_}: + `%%`(TESTOP_instr(v_numtype, testop), $free_numtype(v_numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{v_numtype : numtype, relop : relop_}: + `%%`(RELOP_instr(v_numtype, relop), $free_numtype(v_numtype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_29{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), $free_numtype(numtype_1) +++ $free_numtype(numtype_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{v_vectype : vectype, veclit : uN}: + `%%`(VCONST_instr(v_vectype, veclit), $free_vectype(v_vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{v_vectype : vectype, v_vvunop : vvunop}: + `%%`(VVUNOP_instr(v_vectype, v_vvunop), $free_vectype(v_vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{v_vectype : vectype, v_vvbinop : vvbinop}: + `%%`(VVBINOP_instr(v_vectype, v_vvbinop), $free_vectype(v_vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{v_vectype : vectype, v_vvternop : vvternop}: + `%%`(VVTERNOP_instr(v_vectype, v_vvternop), $free_vectype(v_vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{v_vectype : vectype, v_vvtestop : vvtestop}: + `%%`(VVTESTOP_instr(v_vectype, v_vvtestop), $free_vectype(v_vectype)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{v_shape : shape, vunop : vunop_}: + `%%`(VUNOP_instr(v_shape, vunop), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{v_shape : shape, vbinop : vbinop_}: + `%%`(VBINOP_instr(v_shape, vbinop), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{v_shape : shape, vternop : vternop_}: + `%%`(VTERNOP_instr(v_shape, vternop), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{v_shape : shape, vtestop : vtestop_}: + `%%`(VTESTOP_instr(v_shape, vtestop), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{v_shape : shape, vrelop : vrelop_}: + `%%`(VRELOP_instr(v_shape, vrelop), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{v_ishape : ishape, vshiftop : vshiftop_}: + `%%`(VSHIFTOP_instr(v_ishape, vshiftop), $free_shape($proj_ishape_0(v_ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{v_ishape : ishape}: + `%%`(VBITMASK_instr(v_ishape), $free_shape($proj_ishape_0(v_ishape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{v_bshape : bshape, vswizzlop : vswizzlop_}: + `%%`(VSWIZZLOP_instr(v_bshape, vswizzlop), $free_shape($proj_bshape_0(v_bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{v_bshape : bshape, laneidx_lst : laneidx*}: + `%%`(VSHUFFLE_instr(v_bshape, laneidx_lst), $free_shape($proj_bshape_0(v_bshape).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_44{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_45{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_46{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_47{ishape_1 : ishape, ishape_2 : ishape, v_sx : sx}: + `%%`(VNARROW_instr(ishape_1, ishape_2, v_sx), $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_48{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), $free_shape(shape_1) +++ $free_shape(shape_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{v_shape : shape}: + `%%`(VSPLAT_instr(v_shape), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_50{v_shape : shape, sx_opt : sx?, v_laneidx : uN}: + `%%`(VEXTRACT_LANE_instr(v_shape, sx_opt, v_laneidx), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{v_shape : shape, v_laneidx : uN}: + `%%`(VREPLACE_LANE_instr(v_shape, v_laneidx), $free_shape(v_shape)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_52{v_heaptype : heaptype, var_0 : free}: + `%%`(REF_NULL_instr(v_heaptype), var_0) + -- fun_free_heaptype: `%%`(v_heaptype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_53: + `%%`(REF_IS_NULL_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_54: + `%%`(REF_AS_NON_NULL_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_55: + `%%`(REF_EQ_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_56{v_reftype : reftype, var_0 : free}: + `%%`(REF_TEST_instr(v_reftype), var_0) + -- fun_free_reftype: `%%`(v_reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_57{v_reftype : reftype, var_0 : free}: + `%%`(REF_CAST_instr(v_reftype), var_0) + -- fun_free_reftype: `%%`(v_reftype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_58{v_funcidx : uN}: + `%%`(REF_FUNC_instr(v_funcidx), $free_funcidx(v_funcidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_59: + `%%`(REF_I31_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_60{v_sx : sx}: + `%%`(I31_GET_instr(v_sx), {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{v_typeidx : uN}: + `%%`(STRUCT_NEW_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{v_typeidx : uN}: + `%%`(STRUCT_NEW_DEFAULT_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_63{sx_opt : sx?, v_typeidx : uN, v_u32 : uN}: + `%%`(STRUCT_GET_instr(sx_opt, v_typeidx, v_u32), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{v_typeidx : uN, v_u32 : uN}: + `%%`(STRUCT_SET_instr(v_typeidx, v_u32), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{v_typeidx : uN}: + `%%`(ARRAY_NEW_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{v_typeidx : uN}: + `%%`(ARRAY_NEW_DEFAULT_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{v_typeidx : uN, v_u32 : uN}: + `%%`(ARRAY_NEW_FIXED_instr(v_typeidx, v_u32), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{v_typeidx : uN, v_dataidx : uN}: + `%%`(ARRAY_NEW_DATA_instr(v_typeidx, v_dataidx), $free_typeidx(v_typeidx) +++ $free_dataidx(v_dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{v_typeidx : uN, v_elemidx : uN}: + `%%`(ARRAY_NEW_ELEM_instr(v_typeidx, v_elemidx), $free_typeidx(v_typeidx) +++ $free_elemidx(v_elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{sx_opt : sx?, v_typeidx : uN}: + `%%`(ARRAY_GET_instr(sx_opt, v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{v_typeidx : uN}: + `%%`(ARRAY_SET_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_72: + `%%`(ARRAY_LEN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{v_typeidx : uN}: + `%%`(ARRAY_FILL_instr(v_typeidx), $free_typeidx(v_typeidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_74{typeidx_1 : uN, typeidx_2 : uN}: + `%%`(ARRAY_COPY_instr(typeidx_1, typeidx_2), $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{v_typeidx : uN, v_dataidx : uN}: + `%%`(ARRAY_INIT_DATA_instr(v_typeidx, v_dataidx), $free_typeidx(v_typeidx) +++ $free_dataidx(v_dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{v_typeidx : uN, v_elemidx : uN}: + `%%`(ARRAY_INIT_ELEM_instr(v_typeidx, v_elemidx), $free_typeidx(v_typeidx) +++ $free_elemidx(v_elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_77: + `%%`(EXTERN_CONVERT_ANY_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_78: + `%%`(ANY_CONVERT_EXTERN_instr, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{v_localidx : uN}: + `%%`(LOCAL_GET_instr(v_localidx), $free_localidx(v_localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{v_localidx : uN}: + `%%`(LOCAL_SET_instr(v_localidx), $free_localidx(v_localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{v_localidx : uN}: + `%%`(LOCAL_TEE_instr(v_localidx), $free_localidx(v_localidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{v_globalidx : uN}: + `%%`(GLOBAL_GET_instr(v_globalidx), $free_globalidx(v_globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{v_globalidx : uN}: + `%%`(GLOBAL_SET_instr(v_globalidx), $free_globalidx(v_globalidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{v_tableidx : uN}: + `%%`(TABLE_GET_instr(v_tableidx), $free_tableidx(v_tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{v_tableidx : uN}: + `%%`(TABLE_SET_instr(v_tableidx), $free_tableidx(v_tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{v_tableidx : uN}: + `%%`(TABLE_SIZE_instr(v_tableidx), $free_tableidx(v_tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{v_tableidx : uN}: + `%%`(TABLE_GROW_instr(v_tableidx), $free_tableidx(v_tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{v_tableidx : uN}: + `%%`(TABLE_FILL_instr(v_tableidx), $free_tableidx(v_tableidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_89{tableidx_1 : uN, tableidx_2 : uN}: + `%%`(TABLE_COPY_instr(tableidx_1, tableidx_2), $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{v_tableidx : uN, v_elemidx : uN}: + `%%`(TABLE_INIT_instr(v_tableidx, v_elemidx), $free_tableidx(v_tableidx) +++ $free_elemidx(v_elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{v_elemidx : uN}: + `%%`(ELEM_DROP_instr(v_elemidx), $free_elemidx(v_elemidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_92{v_numtype : numtype, loadop_opt : loadop_?, v_memidx : uN, v_memarg : memarg}: + `%%`(LOAD_instr(v_numtype, loadop_opt, v_memidx, v_memarg), $free_numtype(v_numtype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_93{v_numtype : numtype, storeop_opt : storeop_?, v_memidx : uN, v_memarg : memarg}: + `%%`(STORE_instr(v_numtype, storeop_opt, v_memidx, v_memarg), $free_numtype(v_numtype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_94{v_vectype : vectype, vloadop_opt : vloadop_?, v_memidx : uN, v_memarg : memarg}: + `%%`(VLOAD_instr(v_vectype, vloadop_opt, v_memidx, v_memarg), $free_vectype(v_vectype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_95{v_vectype : vectype, v_sz : sz, v_memidx : uN, v_memarg : memarg, v_laneidx : uN}: + `%%`(VLOAD_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx), $free_vectype(v_vectype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_96{v_vectype : vectype, v_memidx : uN, v_memarg : memarg}: + `%%`(VSTORE_instr(v_vectype, v_memidx, v_memarg), $free_vectype(v_vectype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_97{v_vectype : vectype, v_sz : sz, v_memidx : uN, v_memarg : memarg, v_laneidx : uN}: + `%%`(VSTORE_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx), $free_vectype(v_vectype) +++ $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{v_memidx : uN}: + `%%`(MEMORY_SIZE_instr(v_memidx), $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{v_memidx : uN}: + `%%`(MEMORY_GROW_instr(v_memidx), $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{v_memidx : uN}: + `%%`(MEMORY_FILL_instr(v_memidx), $free_memidx(v_memidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_101{memidx_1 : uN, memidx_2 : uN}: + `%%`(MEMORY_COPY_instr(memidx_1, memidx_2), $free_memidx(memidx_1) +++ $free_memidx(memidx_2)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{v_memidx : uN, v_dataidx : uN}: + `%%`(MEMORY_INIT_instr(v_memidx, v_dataidx), $free_memidx(v_memidx) +++ $free_dataidx(v_dataidx)) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{v_dataidx : uN}: + `%%`(DATA_DROP_instr(v_dataidx), $free_dataidx(v_dataidx)) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation fun_free_block: `%%`(instr*, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule fun_free_block_case_0{instr_lst : instr*, var_2_lst : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr_lst, v_free[LABELS_free = var_0]) + -- let{v_free : free} v_free = var_1 + -- (fun_free_instr: `%%`(instr_5, var_2))*{var_2 <- var_2_lst, instr_5 <- instr_lst} + -- if (|var_2_lst| = |instr_lst|) + -- fun_free_list: `%%`(var_2_lst, var_1) + -- fun_shift_labelidxs: `%%`(v_free.LABELS_free, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec rec { -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.1-420.30 -def $free_instr(v_instr : instr) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:435.1-435.26 - def $free_instr(NOP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:436.1-436.34 - def $free_instr(UNREACHABLE_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:437.1-437.27 - def $free_instr(DROP_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:438.1-438.86 - def $free_instr{valtype_lst_opt : valtype*?}(SELECT_instr(valtype_lst_opt)) = $free_opt($free_list($free_valtype(v_valtype)*{v_valtype <- valtype_lst})?{valtype_lst <- valtype_lst_opt}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:440.1-440.92 - def $free_instr{v_blocktype : blocktype, instr_lst : instr*}(BLOCK_instr(v_blocktype, instr_lst)) = $free_blocktype(v_blocktype) +++ $free_block(instr_lst) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:441.1-441.91 - def $free_instr{v_blocktype : blocktype, instr_lst : instr*}(LOOP_instr(v_blocktype, instr_lst)) = $free_blocktype(v_blocktype) +++ $free_block(instr_lst) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:442.1-443.79 - def $free_instr{v_blocktype : blocktype, instr_1_lst : instr*, instr_2_lst : instr*}(`IF%%ELSE%`_instr(v_blocktype, instr_1_lst, instr_2_lst)) = $free_blocktype(v_blocktype) +++ $free_block(instr_1_lst) +++ $free_block(instr_2_lst) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:445.1-445.56 - def $free_instr{v_labelidx : uN}(BR_instr(v_labelidx)) = $free_labelidx(v_labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:446.1-446.59 - def $free_instr{v_labelidx : uN}(BR_IF_instr(v_labelidx)) = $free_labelidx(v_labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:447.1-448.69 - def $free_instr{labelidx_lst : labelidx*, labelidx' : uN}(BR_TABLE_instr(labelidx_lst, labelidx')) = $free_list($free_labelidx(v_labelidx)*{v_labelidx <- labelidx_lst}) +++ $free_labelidx(labelidx') - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:449.1-449.64 - def $free_instr{v_labelidx : uN}(BR_ON_NULL_instr(v_labelidx)) = $free_labelidx(v_labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:450.1-450.68 - def $free_instr{v_labelidx : uN}(BR_ON_NON_NULL_instr(v_labelidx)) = $free_labelidx(v_labelidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:451.1-452.83 - def $free_instr{v_labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_instr(v_labelidx, reftype_1, reftype_2)) = $free_labelidx(v_labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:453.1-454.83 - def $free_instr{v_labelidx : uN, reftype_1 : reftype, reftype_2 : reftype}(BR_ON_CAST_FAIL_instr(v_labelidx, reftype_1, reftype_2)) = $free_labelidx(v_labelidx) +++ $free_reftype(reftype_1) +++ $free_reftype(reftype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:456.1-456.55 - def $free_instr{v_funcidx : uN}(CALL_instr(v_funcidx)) = $free_funcidx(v_funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:457.1-457.59 - def $free_instr{v_typeuse : typeuse}(CALL_REF_instr(v_typeuse)) = $free_typeuse(v_typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:458.1-459.53 - def $free_instr{v_tableidx : uN, v_typeuse : typeuse}(CALL_INDIRECT_instr(v_tableidx, v_typeuse)) = $free_tableidx(v_tableidx) +++ $free_typeuse(v_typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:460.1-460.29 - def $free_instr(RETURN_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:461.1-461.62 - def $free_instr{v_funcidx : uN}(RETURN_CALL_instr(v_funcidx)) = $free_funcidx(v_funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:462.1-462.66 - def $free_instr{v_typeuse : typeuse}(RETURN_CALL_REF_instr(v_typeuse)) = $free_typeuse(v_typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:463.1-464.53 - def $free_instr{v_tableidx : uN, v_typeuse : typeuse}(RETURN_CALL_INDIRECT_instr(v_tableidx, v_typeuse)) = $free_tableidx(v_tableidx) +++ $free_typeuse(v_typeuse) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:466.1-466.53 - def $free_instr{v_tagidx : uN}(THROW_instr(v_tagidx)) = $free_tagidx(v_tagidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:467.1-467.32 - def $free_instr(THROW_REF_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:468.1-469.99 - def $free_instr{v_blocktype : blocktype, catch_lst : catch*, instr_lst : instr*}(TRY_TABLE_instr(v_blocktype, `%`_list(catch_lst), instr_lst)) = $free_blocktype(v_blocktype) +++ $free_list($free_catch(v_catch)*{v_catch <- catch_lst}) +++ $free_list($free_instr(v_instr)*{v_instr <- instr_lst}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:471.1-471.63 - def $free_instr{v_numtype : numtype, numlit : num_}(CONST_instr(v_numtype, numlit)) = $free_numtype(v_numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:472.1-472.60 - def $free_instr{v_numtype : numtype, unop : unop_}(UNOP_instr(v_numtype, unop)) = $free_numtype(v_numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:473.1-473.62 - def $free_instr{v_numtype : numtype, binop : binop_}(BINOP_instr(v_numtype, binop)) = $free_numtype(v_numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:474.1-474.64 - def $free_instr{v_numtype : numtype, testop : testop_}(TESTOP_instr(v_numtype, testop)) = $free_numtype(v_numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:475.1-475.62 - def $free_instr{v_numtype : numtype, relop : relop_}(RELOP_instr(v_numtype, relop)) = $free_numtype(v_numtype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:476.1-477.55 - def $free_instr{numtype_1 : numtype, numtype_2 : numtype, cvtop : cvtop__}(CVTOP_instr(numtype_1, numtype_2, cvtop)) = $free_numtype(numtype_1) +++ $free_numtype(numtype_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:479.1-479.64 - def $free_instr{v_vectype : vectype, veclit : uN}(VCONST_instr(v_vectype, veclit)) = $free_vectype(v_vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:480.1-480.64 - def $free_instr{v_vectype : vectype, v_vvunop : vvunop}(VVUNOP_instr(v_vectype, v_vvunop)) = $free_vectype(v_vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:481.1-481.66 - def $free_instr{v_vectype : vectype, v_vvbinop : vvbinop}(VVBINOP_instr(v_vectype, v_vvbinop)) = $free_vectype(v_vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:482.1-482.68 - def $free_instr{v_vectype : vectype, v_vvternop : vvternop}(VVTERNOP_instr(v_vectype, v_vvternop)) = $free_vectype(v_vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:483.1-483.68 - def $free_instr{v_vectype : vectype, v_vvtestop : vvtestop}(VVTESTOP_instr(v_vectype, v_vvtestop)) = $free_vectype(v_vectype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:484.1-484.56 - def $free_instr{v_shape : shape, vunop : vunop_}(VUNOP_instr(v_shape, vunop)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:485.1-485.58 - def $free_instr{v_shape : shape, vbinop : vbinop_}(VBINOP_instr(v_shape, vbinop)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:486.1-486.60 - def $free_instr{v_shape : shape, vternop : vternop_}(VTERNOP_instr(v_shape, vternop)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:487.1-487.60 - def $free_instr{v_shape : shape, vtestop : vtestop_}(VTESTOP_instr(v_shape, vtestop)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:488.1-488.58 - def $free_instr{v_shape : shape, vrelop : vrelop_}(VRELOP_instr(v_shape, vrelop)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:489.1-489.64 - def $free_instr{v_ishape : ishape, vshiftop : vshiftop_}(VSHIFTOP_instr(v_ishape, vshiftop)) = $free_shape($proj_ishape_0(v_ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:490.1-490.55 - def $free_instr{v_ishape : ishape}(VBITMASK_instr(v_ishape)) = $free_shape($proj_ishape_0(v_ishape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:491.1-491.66 - def $free_instr{v_bshape : bshape, vswizzlop : vswizzlop_}(VSWIZZLOP_instr(v_bshape, vswizzlop)) = $free_shape($proj_bshape_0(v_bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:492.1-492.64 - def $free_instr{v_bshape : bshape, laneidx_lst : laneidx*}(VSHUFFLE_instr(v_bshape, laneidx_lst)) = $free_shape($proj_bshape_0(v_bshape).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:493.1-494.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextunop : vextunop__}(VEXTUNOP_instr(ishape_1, ishape_2, vextunop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:495.1-496.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextbinop : vextbinop__}(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:497.1-498.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, vextternop : vextternop__}(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:499.1-500.49 - def $free_instr{ishape_1 : ishape, ishape_2 : ishape, v_sx : sx}(VNARROW_instr(ishape_1, ishape_2, v_sx)) = $free_shape($proj_ishape_0(ishape_1).0) +++ $free_shape($proj_ishape_0(ishape_2).0) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:501.1-502.47 - def $free_instr{shape_1 : shape, shape_2 : shape, vcvtop : vcvtop__}(VCVTOP_instr(shape_1, shape_2, vcvtop)) = $free_shape(shape_1) +++ $free_shape(shape_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:503.1-503.51 - def $free_instr{v_shape : shape}(VSPLAT_instr(v_shape)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:504.1-504.70 - def $free_instr{v_shape : shape, sx_opt : sx?, v_laneidx : uN}(VEXTRACT_LANE_instr(v_shape, sx_opt, v_laneidx)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:505.1-505.66 - def $free_instr{v_shape : shape, v_laneidx : uN}(VREPLACE_LANE_instr(v_shape, v_laneidx)) = $free_shape(v_shape) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:507.1-507.62 - def $free_instr{v_heaptype : heaptype}(`REF.NULL`_instr(v_heaptype)) = $free_heaptype(v_heaptype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:508.1-508.34 - def $free_instr(`REF.IS_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:509.1-509.38 - def $free_instr(`REF.AS_NON_NULL`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:510.1-510.29 - def $free_instr(`REF.EQ`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:511.1-511.59 - def $free_instr{v_reftype : reftype}(`REF.TEST`_instr(v_reftype)) = $free_reftype(v_reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:512.1-512.59 - def $free_instr{v_reftype : reftype}(`REF.CAST`_instr(v_reftype)) = $free_reftype(v_reftype) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:513.1-513.59 - def $free_instr{v_funcidx : uN}(`REF.FUNC`_instr(v_funcidx)) = $free_funcidx(v_funcidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:514.1-514.30 - def $free_instr(`REF.I31`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:516.1-516.33 - def $free_instr{v_sx : sx}(`I31.GET`_instr(v_sx)) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:518.1-518.61 - def $free_instr{v_typeidx : uN}(`STRUCT.NEW`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:519.1-519.69 - def $free_instr{v_typeidx : uN}(`STRUCT.NEW_DEFAULT`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:520.1-520.69 - def $free_instr{sx_opt : sx?, v_typeidx : uN, v_u32 : uN}(`STRUCT.GET`_instr(sx_opt, v_typeidx, v_u32)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:521.1-521.65 - def $free_instr{v_typeidx : uN, v_u32 : uN}(`STRUCT.SET`_instr(v_typeidx, v_u32)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:523.1-523.60 - def $free_instr{v_typeidx : uN}(`ARRAY.NEW`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:524.1-524.68 - def $free_instr{v_typeidx : uN}(`ARRAY.NEW_DEFAULT`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:525.1-525.70 - def $free_instr{v_typeidx : uN, v_u32 : uN}(`ARRAY.NEW_FIXED`_instr(v_typeidx, v_u32)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:526.1-527.51 - def $free_instr{v_typeidx : uN, v_dataidx : uN}(`ARRAY.NEW_DATA`_instr(v_typeidx, v_dataidx)) = $free_typeidx(v_typeidx) +++ $free_dataidx(v_dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:528.1-529.51 - def $free_instr{v_typeidx : uN, v_elemidx : uN}(`ARRAY.NEW_ELEM`_instr(v_typeidx, v_elemidx)) = $free_typeidx(v_typeidx) +++ $free_elemidx(v_elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:530.1-530.64 - def $free_instr{sx_opt : sx?, v_typeidx : uN}(`ARRAY.GET`_instr(sx_opt, v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:531.1-531.60 - def $free_instr{v_typeidx : uN}(`ARRAY.SET`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:532.1-532.32 - def $free_instr(`ARRAY.LEN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:533.1-533.61 - def $free_instr{v_typeidx : uN}(`ARRAY.FILL`_instr(v_typeidx)) = $free_typeidx(v_typeidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:534.1-535.55 - def $free_instr{typeidx_1 : uN, typeidx_2 : uN}(`ARRAY.COPY`_instr(typeidx_1, typeidx_2)) = $free_typeidx(typeidx_1) +++ $free_typeidx(typeidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:536.1-537.51 - def $free_instr{v_typeidx : uN, v_dataidx : uN}(`ARRAY.INIT_DATA`_instr(v_typeidx, v_dataidx)) = $free_typeidx(v_typeidx) +++ $free_dataidx(v_dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:538.1-539.51 - def $free_instr{v_typeidx : uN, v_elemidx : uN}(`ARRAY.INIT_ELEM`_instr(v_typeidx, v_elemidx)) = $free_typeidx(v_typeidx) +++ $free_elemidx(v_elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:541.1-541.41 - def $free_instr(`EXTERN.CONVERT_ANY`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:542.1-542.41 - def $free_instr(`ANY.CONVERT_EXTERN`_instr) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:544.1-544.63 - def $free_instr{v_localidx : uN}(`LOCAL.GET`_instr(v_localidx)) = $free_localidx(v_localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:545.1-545.63 - def $free_instr{v_localidx : uN}(`LOCAL.SET`_instr(v_localidx)) = $free_localidx(v_localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:546.1-546.63 - def $free_instr{v_localidx : uN}(`LOCAL.TEE`_instr(v_localidx)) = $free_localidx(v_localidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:548.1-548.67 - def $free_instr{v_globalidx : uN}(`GLOBAL.GET`_instr(v_globalidx)) = $free_globalidx(v_globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:549.1-549.67 - def $free_instr{v_globalidx : uN}(`GLOBAL.SET`_instr(v_globalidx)) = $free_globalidx(v_globalidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:551.1-551.63 - def $free_instr{v_tableidx : uN}(`TABLE.GET`_instr(v_tableidx)) = $free_tableidx(v_tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:552.1-552.63 - def $free_instr{v_tableidx : uN}(`TABLE.SET`_instr(v_tableidx)) = $free_tableidx(v_tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:553.1-553.64 - def $free_instr{v_tableidx : uN}(`TABLE.SIZE`_instr(v_tableidx)) = $free_tableidx(v_tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:554.1-554.64 - def $free_instr{v_tableidx : uN}(`TABLE.GROW`_instr(v_tableidx)) = $free_tableidx(v_tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:555.1-555.64 - def $free_instr{v_tableidx : uN}(`TABLE.FILL`_instr(v_tableidx)) = $free_tableidx(v_tableidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:556.1-557.59 - def $free_instr{tableidx_1 : uN, tableidx_2 : uN}(`TABLE.COPY`_instr(tableidx_1, tableidx_2)) = $free_tableidx(tableidx_1) +++ $free_tableidx(tableidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:558.1-559.53 - def $free_instr{v_tableidx : uN, v_elemidx : uN}(`TABLE.INIT`_instr(v_tableidx, v_elemidx)) = $free_tableidx(v_tableidx) +++ $free_elemidx(v_elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:560.1-560.60 - def $free_instr{v_elemidx : uN}(`ELEM.DROP`_instr(v_elemidx)) = $free_elemidx(v_elemidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:562.1-563.49 - def $free_instr{v_numtype : numtype, loadop_opt : loadop_?, v_memidx : uN, v_memarg : memarg}(LOAD_instr(v_numtype, loadop_opt, v_memidx, v_memarg)) = $free_numtype(v_numtype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:564.1-565.49 - def $free_instr{v_numtype : numtype, storeop_opt : storeop_?, v_memidx : uN, v_memarg : memarg}(STORE_instr(v_numtype, storeop_opt, v_memidx, v_memarg)) = $free_numtype(v_numtype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:566.1-567.49 - def $free_instr{v_vectype : vectype, vloadop_opt : vloadop_?, v_memidx : uN, v_memarg : memarg}(VLOAD_instr(v_vectype, vloadop_opt, v_memidx, v_memarg)) = $free_vectype(v_vectype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:568.1-569.49 - def $free_instr{v_vectype : vectype, v_sz : sz, v_memidx : uN, v_memarg : memarg, v_laneidx : uN}(VLOAD_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx)) = $free_vectype(v_vectype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:570.1-571.49 - def $free_instr{v_vectype : vectype, v_memidx : uN, v_memarg : memarg}(VSTORE_instr(v_vectype, v_memidx, v_memarg)) = $free_vectype(v_vectype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:572.1-573.49 - def $free_instr{v_vectype : vectype, v_sz : sz, v_memidx : uN, v_memarg : memarg, v_laneidx : uN}(VSTORE_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx)) = $free_vectype(v_vectype) +++ $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:574.1-574.59 - def $free_instr{v_memidx : uN}(`MEMORY.SIZE`_instr(v_memidx)) = $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:575.1-575.59 - def $free_instr{v_memidx : uN}(`MEMORY.GROW`_instr(v_memidx)) = $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:576.1-576.59 - def $free_instr{v_memidx : uN}(`MEMORY.FILL`_instr(v_memidx)) = $free_memidx(v_memidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:577.1-578.51 - def $free_instr{memidx_1 : uN, memidx_2 : uN}(`MEMORY.COPY`_instr(memidx_1, memidx_2)) = $free_memidx(memidx_1) +++ $free_memidx(memidx_2) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:579.1-580.49 - def $free_instr{v_memidx : uN, v_dataidx : uN}(`MEMORY.INIT`_instr(v_memidx, v_dataidx)) = $free_memidx(v_memidx) +++ $free_dataidx(v_dataidx) - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:581.1-581.60 - def $free_instr{v_dataidx : uN}(`DATA.DROP`_instr(v_dataidx)) = $free_dataidx(v_dataidx) - -;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.1-421.31 -def $free_block(var_0 : instr*) : free - ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:589.1-590.47 - def $free_block{instr_lst : instr*}(instr_lst) = v_free[LABELS_free = $shift_labelidxs(v_free.LABELS_free)] - -- let{v_free : free} v_free = $free_list($free_instr(instr#5)*{instr#5 <- instr_lst}) +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 +relation free_instr_is_wf: `%%`(v_instr : instr, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule free_instr_is_wf_0{v_instr : instr, ret_val : free, var_0 : free}: + `%%`(v_instr, ret_val) + -- wf_instr: `%`(v_instr) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_instr: `%%`(v_instr, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 +relation free_block_is_wf: `%%`(var_0 : instr*, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:421.6-421.17 + rule free_block_is_wf_0{var_0 : instr*, ret_val : free, var_1 : free}: + `%%`(var_0, ret_val) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_free: `%`(ret_val) + -- fun_free_block: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_expr(v_expr : expr) : free +relation fun_free_expr: `%%`(expr, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_expr_case_0{instr_lst : instr*, var_1_lst : free*, var_0 : free}: + `%%`(instr_lst, var_0) + -- (fun_free_instr: `%%`(v_instr, var_1))*{var_1 <- var_1_lst, v_instr <- instr_lst} + -- if (|var_1_lst| = |instr_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation free_expr_is_wf: `%%`(v_expr : expr, ret_val : free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_expr{instr_lst : instr*}(instr_lst) = $free_list($free_instr(v_instr)*{v_instr <- instr_lst}) + rule free_expr_is_wf_0{v_expr : expr, ret_val : free, var_0 : free}: + `%%`(v_expr, ret_val) + -- (wf_instr: `%`(v_expr))*{v_expr <- v_expr} + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_expr: `%%`(v_expr, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = @@ -5060,19 +6568,55 @@ relation wf_module: `%`(module) -- (wf_start: `%`(v_start))?{v_start <- start_opt} ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_type(v_type : type) : free +relation fun_free_type: `%%`(type, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_type_case_0{v_rectype : rectype, var_0 : free}: + `%%`(TYPE_type(v_rectype), var_0) + -- fun_free_rectype: `%%`(v_rectype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_type_is_wf: `%%`(v_type : type, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_type_is_wf_0{v_type : type, ret_val : free, var_0 : free}: + `%%`(v_type, ret_val) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_type: `%%`(v_type, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_tag: `%%`(tag, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_tag_case_0{v_tagtype : typeuse, var_0 : free}: + `%%`(TAG_tag(v_tagtype), var_0) + -- fun_free_tagtype: `%%`(v_tagtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_tag_is_wf: `%%`(v_tag : tag, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_type{v_rectype : rectype}(TYPE_type(v_rectype)) = $free_rectype(v_rectype) + rule free_tag_is_wf_0{v_tag : tag, ret_val : free, var_0 : free}: + `%%`(v_tag, ret_val) + -- wf_tag: `%`(v_tag) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_tag: `%%`(v_tag, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_tag(v_tag : tag) : free +relation fun_free_global: `%%`(global, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{v_tagtype : typeuse}(TAG_tag(v_tagtype)) = $free_tagtype(v_tagtype) + rule fun_free_global_case_0{v_globaltype : globaltype, v_expr : instr*, var_1 : free, var_0 : free}: + `%%`(GLOBAL_global(v_globaltype, v_expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(v_expr, var_1) + -- fun_free_globaltype: `%%`(v_globaltype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_global(v_global : global) : free +relation free_global_is_wf: `%%`(v_global : global, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_global{v_globaltype : globaltype, v_expr : instr*}(GLOBAL_global(v_globaltype, v_expr)) = $free_globaltype(v_globaltype) +++ $free_expr(v_expr) + rule free_global_is_wf_0{v_global : global, ret_val : free, var_0 : free}: + `%%`(v_global, ret_val) + -- wf_global: `%`(v_global) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_global: `%%`(v_global, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_mem(v_mem : mem) : free @@ -5080,48 +6624,152 @@ def $free_mem(v_mem : mem) : free def $free_mem{v_memtype : memtype}(MEMORY_mem(v_memtype)) = $free_memtype(v_memtype) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(v_table : table) : free +relation free_mem_is_wf: `%%`(v_mem : mem, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_mem_is_wf_0{v_mem : mem, ret_val : free}: + `%%`(v_mem, ret_val) + -- wf_mem: `%`(v_mem) + -- if (ret_val = $free_mem(v_mem)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_table: `%%`(table, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_table_case_0{v_tabletype : tabletype, v_expr : instr*, var_1 : free, var_0 : free}: + `%%`(TABLE_table(v_tabletype, v_expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(v_expr, var_1) + -- fun_free_tabletype: `%%`(v_tabletype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_table_is_wf: `%%`(v_table : table, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_table_is_wf_0{v_table : table, ret_val : free, var_0 : free}: + `%%`(v_table, ret_val) + -- wf_table: `%`(v_table) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_table: `%%`(v_table, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_local: `%%`(local, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_local_case_0{t : valtype, var_0 : free}: + `%%`(LOCAL_local(t), var_0) + -- fun_free_valtype: `%%`(t, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_local_is_wf: `%%`(v_local : local, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_table{v_tabletype : tabletype, v_expr : instr*}(TABLE_table(v_tabletype, v_expr)) = $free_tabletype(v_tabletype) +++ $free_expr(v_expr) + rule free_local_is_wf_0{v_local : local, ret_val : free, var_0 : free}: + `%%`(v_local, ret_val) + -- wf_local: `%`(v_local) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_local: `%%`(v_local, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_local(v_local : local) : free +relation fun_free_func: `%%`(func, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + rule fun_free_func_case_0{v_typeidx : uN, local_lst : local*, v_expr : instr*, var_2 : free, var_1_lst : free*, var_0 : free}: + `%%`(FUNC_func(v_typeidx, local_lst, v_expr), $free_typeidx(v_typeidx) +++ var_0 +++ var_2[LOCALS_free = []]) + -- fun_free_block: `%%`(v_expr, var_2) + -- (fun_free_local: `%%`(v_local, var_1))*{var_1 <- var_1_lst, v_local <- local_lst} + -- if (|var_1_lst| = |local_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_func(v_func : func) : free +relation free_func_is_wf: `%%`(v_func : func, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_func{v_typeidx : uN, local_lst : local*, v_expr : instr*}(FUNC_func(v_typeidx, local_lst, v_expr)) = $free_typeidx(v_typeidx) +++ $free_list($free_local(v_local)*{v_local <- local_lst}) +++ $free_block(v_expr)[LOCALS_free = []] + rule free_func_is_wf_0{v_func : func, ret_val : free, var_0 : free}: + `%%`(v_func, ret_val) + -- wf_func: `%`(v_func) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_func: `%%`(v_func, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(v_datamode : datamode) : free +relation fun_free_datamode: `%%`(datamode, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode{v_memidx : uN, v_expr : instr*}(ACTIVE_datamode(v_memidx, v_expr)) = $free_memidx(v_memidx) +++ $free_expr(v_expr) + rule fun_free_datamode_case_0{v_memidx : uN, v_expr : instr*, var_0 : free}: + `%%`(ACTIVE_datamode(v_memidx, v_expr), $free_memidx(v_memidx) +++ var_0) + -- fun_free_expr: `%%`(v_expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_datamode_case_1: + `%%`(PASSIVE_datamode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_datamode_is_wf: `%%`(v_datamode : datamode, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_datamode_is_wf_0{v_datamode : datamode, ret_val : free, var_0 : free}: + `%%`(v_datamode, ret_val) + -- wf_datamode: `%`(v_datamode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_datamode: `%%`(v_datamode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_data: `%%`(data, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_data_case_0{byte_lst : byte*, v_datamode : datamode, var_0 : free}: + `%%`(DATA_data(byte_lst, v_datamode), var_0) + -- fun_free_datamode: `%%`(v_datamode, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(v_data : data) : free +relation free_data_is_wf: `%%`(v_data : data, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_data{byte_lst : byte*, v_datamode : datamode}(DATA_data(byte_lst, v_datamode)) = $free_datamode(v_datamode) + rule free_data_is_wf_0{v_data : data, ret_val : free, var_0 : free}: + `%%`(v_data, ret_val) + -- wf_data: `%`(v_data) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_data: `%%`(v_data, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elemmode(v_elemmode : elemmode) : free +relation fun_free_elemmode: `%%`(elemmode, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode{v_tableidx : uN, v_expr : instr*}(ACTIVE_elemmode(v_tableidx, v_expr)) = $free_tableidx(v_tableidx) +++ $free_expr(v_expr) + rule fun_free_elemmode_case_0{v_tableidx : uN, v_expr : instr*, var_0 : free}: + `%%`(ACTIVE_elemmode(v_tableidx, v_expr), $free_tableidx(v_tableidx) +++ var_0) + -- fun_free_expr: `%%`(v_expr, var_0) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_1: + `%%`(PASSIVE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_elemmode_case_2: + `%%`(DECLARE_elemmode, {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_elemmode_is_wf: `%%`(v_elemmode : elemmode, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule free_elemmode_is_wf_0{v_elemmode : elemmode, ret_val : free, var_0 : free}: + `%%`(v_elemmode, ret_val) + -- wf_elemmode: `%`(v_elemmode) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elemmode: `%%`(v_elemmode, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_elem: `%%`(elem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(DECLARE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} - -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + rule fun_free_elem_case_0{v_reftype : reftype, expr_lst : expr*, v_elemmode : elemmode, var_3 : free, var_2_lst : free*, var_1 : free, var_0 : free}: + `%%`(ELEM_elem(v_reftype, expr_lst, v_elemmode), var_0 +++ var_1 +++ var_3) + -- fun_free_elemmode: `%%`(v_elemmode, var_3) + -- (fun_free_expr: `%%`(v_expr, var_2))*{var_2 <- var_2_lst, v_expr <- expr_lst} + -- if (|var_2_lst| = |expr_lst|) + -- fun_free_list: `%%`(var_2_lst, var_1) + -- fun_free_reftype: `%%`(v_reftype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_elem(v_elem : elem) : free +relation free_elem_is_wf: `%%`(v_elem : elem, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elem{v_reftype : reftype, expr_lst : expr*, v_elemmode : elemmode}(ELEM_elem(v_reftype, expr_lst, v_elemmode)) = $free_reftype(v_reftype) +++ $free_list($free_expr(v_expr)*{v_expr <- expr_lst}) +++ $free_elemmode(v_elemmode) + rule free_elem_is_wf_0{v_elem : elem, ret_val : free, var_0 : free}: + `%%`(v_elem, ret_val) + -- wf_elem: `%`(v_elem) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_elem: `%%`(v_elem, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_start(v_start : start) : free @@ -5129,9 +6777,30 @@ def $free_start(v_start : start) : free def $free_start{v_funcidx : uN}(START_start(v_funcidx)) = $free_funcidx(v_funcidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(v_import : import) : free +relation free_start_is_wf: `%%`(v_start : start, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_start_is_wf_0{v_start : start, ret_val : free}: + `%%`(v_start, ret_val) + -- wf_start: `%`(v_start) + -- if (ret_val = $free_start(v_start)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_import: `%%`(import, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_import{name_1 : name, name_2 : name, v_externtype : externtype}(IMPORT_import(name_1, name_2, v_externtype)) = $free_externtype(v_externtype) + rule fun_free_import_case_0{name_1 : name, name_2 : name, v_externtype : externtype, var_0 : free}: + `%%`(IMPORT_import(name_1, name_2, v_externtype), var_0) + -- fun_free_externtype: `%%`(v_externtype, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_import_is_wf: `%%`(v_import : import, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_import_is_wf_0{v_import : import, ret_val : free, var_0 : free}: + `%%`(v_import, ret_val) + -- wf_import: `%`(v_import) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_import: `%%`(v_import, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec def $free_export(v_export : export) : free @@ -5139,19 +6808,71 @@ def $free_export(v_export : export) : free def $free_export{v_name : name, v_externidx : externidx}(EXPORT_export(v_name, v_externidx)) = $free_externidx(v_externidx) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(v_module : module) : free +relation free_export_is_wf: `%%`(v_export : export, ret_val : free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule free_export_is_wf_0{v_export : export, ret_val : free}: + `%%`(v_export, ret_val) + -- wf_export: `%`(v_export) + -- if (ret_val = $free_export(v_export)) + -- wf_free: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_module: `%%`(module, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_module_case_0{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, var_17 : free, var_16_lst : free*, var_15 : free, var_14_lst : free*, var_13 : free, var_12_lst : free*, var_11 : free, var_10_lst : free*, var_9 : free, var_8_lst : free*, var_7 : free, var_6 : free, var_5_lst : free*, var_4 : free, var_3_lst : free*, var_2 : free, var_1_lst : free*, var_0 : free}: + `%%`(MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)), var_0 +++ var_2 +++ var_4 +++ var_6 +++ var_7 +++ var_9 +++ var_11 +++ var_13 +++ $free_opt($free_start(v_start)?{v_start <- start_opt}) +++ var_15 +++ var_17) + -- fun_free_list: `%%`($free_export(v_export)*{v_export <- export_lst}, var_17) + -- (fun_free_import: `%%`(v_import, var_16))*{var_16 <- var_16_lst, v_import <- import_lst} + -- if (|var_16_lst| = |import_lst|) + -- fun_free_list: `%%`(var_16_lst, var_15) + -- (fun_free_elem: `%%`(v_elem, var_14))*{var_14 <- var_14_lst, v_elem <- elem_lst} + -- if (|var_14_lst| = |elem_lst|) + -- fun_free_list: `%%`(var_14_lst, var_13) + -- (fun_free_data: `%%`(v_data, var_12))*{var_12 <- var_12_lst, v_data <- data_lst} + -- if (|var_12_lst| = |data_lst|) + -- fun_free_list: `%%`(var_12_lst, var_11) + -- (fun_free_func: `%%`(v_func, var_10))*{var_10 <- var_10_lst, v_func <- func_lst} + -- if (|var_10_lst| = |func_lst|) + -- fun_free_list: `%%`(var_10_lst, var_9) + -- (fun_free_table: `%%`(v_table, var_8))*{var_8 <- var_8_lst, v_table <- table_lst} + -- if (|var_8_lst| = |table_lst|) + -- fun_free_list: `%%`(var_8_lst, var_7) + -- fun_free_list: `%%`($free_mem(v_mem)*{v_mem <- mem_lst}, var_6) + -- (fun_free_global: `%%`(v_global, var_5))*{var_5 <- var_5_lst, v_global <- global_lst} + -- if (|var_5_lst| = |global_lst|) + -- fun_free_list: `%%`(var_5_lst, var_4) + -- (fun_free_tag: `%%`(v_tag, var_3))*{var_3 <- var_3_lst, v_tag <- tag_lst} + -- if (|var_3_lst| = |tag_lst|) + -- fun_free_list: `%%`(var_3_lst, var_2) + -- (fun_free_type: `%%`(v_type, var_1))*{var_1 <- var_1_lst, v_type <- type_lst} + -- if (|var_1_lst| = |type_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation free_module_is_wf: `%%`(v_module : module, ret_val : free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_module{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*}(MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) = $free_list($free_type(v_type)*{v_type <- type_lst}) +++ $free_list($free_tag(v_tag)*{v_tag <- tag_lst}) +++ $free_list($free_global(v_global)*{v_global <- global_lst}) +++ $free_list($free_mem(v_mem)*{v_mem <- mem_lst}) +++ $free_list($free_table(v_table)*{v_table <- table_lst}) +++ $free_list($free_func(v_func)*{v_func <- func_lst}) +++ $free_list($free_data(v_data)*{v_data <- data_lst}) +++ $free_list($free_elem(v_elem)*{v_elem <- elem_lst}) +++ $free_opt($free_start(v_start)?{v_start <- start_opt}) +++ $free_list($free_import(v_import)*{v_import <- import_lst}) +++ $free_list($free_export(v_export)*{v_export <- export_lst}) + rule free_module_is_wf_0{v_module : module, ret_val : free, var_0 : free}: + `%%`(v_module, ret_val) + -- wf_module: `%`(v_module) + -- if (ret_val = var_0) + -- wf_free: `%`(ret_val) + -- fun_free_module: `%%`(v_module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $funcidx_module(v_module : module) : funcidx* +relation fun_funcidx_module: `%%`(module, funcidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $funcidx_module{v_module : module}(v_module) = $free_module(v_module).FUNCS_free + rule fun_funcidx_module_case_0{v_module : module, var_0 : free}: + `%%`(v_module, var_0.FUNCS_free) + -- fun_free_module: `%%`(v_module, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $dataidx_funcs(var_0 : func*) : dataidx* +relation fun_dataidx_funcs: `%%`(func*, dataidx*) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $dataidx_funcs{func_lst : func*}(func_lst) = $free_list($free_func(v_func)*{v_func <- func_lst}).DATAS_free + rule fun_dataidx_funcs_case_0{func_lst : func*, var_1_lst : free*, var_0 : free}: + `%%`(func_lst, var_0.DATAS_free) + -- (fun_free_func: `%%`(v_func, var_1))*{var_1 <- var_1_lst, v_func <- func_lst} + -- if (|var_1_lst| = |func_lst|) + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax init = @@ -5160,24 +6881,24 @@ syntax init = ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax localtype = - | `%%`(v_init : init, v_valtype : valtype) + | mk_localtype(v_init : init, v_valtype : valtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation wf_localtype: `%`(localtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule localtype_case_0{v_init : init, v_valtype : valtype}: - `%`(`%%`_localtype(v_init, v_valtype)) + `%`(mk_localtype_localtype(v_init, v_valtype)) -- wf_valtype: `%`(v_valtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax instrtype = - | `%->_%%`(v_resulttype : resulttype, localidx_lst : localidx*, v_resulttype : resulttype) + | mk_instrtype(v_resulttype : resulttype, localidx_lst : localidx*, v_resulttype : resulttype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation wf_instrtype: `%`(instrtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule instrtype_case_0{v_resulttype : resulttype, localidx_lst : localidx*, resulttype_0 : resulttype}: - `%`(`%->_%%`_instrtype(v_resulttype, localidx_lst, resulttype_0)) + `%`(mk_instrtype_instrtype(v_resulttype, localidx_lst, resulttype_0)) -- (wf_uN: `%%`(32, v_localidx))*{v_localidx <- localidx_lst} ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -5212,60 +6933,147 @@ relation wf_context: `%`(context) -- (wf_uN: `%%`(32, var_11))*{var_11 <- var_11} -- (wf_subtype: `%`(var_12))*{var_12 <- var_12} +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_with_locals_before_fun_with_locals_case_2: `%%%`(context, localidx*, localtype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_1{C : context, x_1 : uN, x_lst : idx*, lct_1 : localtype, lct_lst : localtype*, var_0 : context?}: + `%%%`(C, [x_1] ++ x_lst, [lct_1] ++ lct_lst) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_with_locals_case_0{C : context}: + `%%%`(C, [], []) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.1-49.158 -def $with_locals(v_context : context, var_0 : localidx*, var_1 : localtype*) : context? - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:51.1-51.34 - def $with_locals{C : context}(C, [], []) = ?(C) - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:52.1-52.90 - def $with_locals{C : context, x_1 : uN, x_lst : idx*, lct_1 : localtype, lct_lst : localtype*}(C, [x_1] ++ x_lst, [lct_1] ++ lct_lst) = $with_locals(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x_lst, lct_lst) - def $with_locals{x0 : context, x1 : localidx*, x2 : localtype*}(x0, x1, x2) = ?() - -- otherwise +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation fun_with_locals: `%%%%`(context, localidx*, localtype*, context?) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_0{C : context}: + `%%%%`(C, [], [], ?(C)) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_1{C : context, x_1 : uN, x_lst : idx*, lct_1 : localtype, lct_lst : localtype*, var_0 : context?}: + `%%%%`(C, [x_1] ++ x_lst, [lct_1] ++ lct_lst, var_0) + -- fun_with_locals: `%%%%`(C[LOCALS_context[$proj_uN_0(x_1).0] = lct_1], x_lst, lct_lst, var_0) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule fun_with_locals_case_2{x0 : context, x1 : localidx*, x2 : localtype*}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_with_locals_before_fun_with_locals_case_2: `%%%`(x0, x1, x2) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +rec { + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 +relation with_locals_is_wf: `%%%%`(v_context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:49.6-49.18 + rule with_locals_is_wf_0{v_context : context, var_0 : localidx*, var_1 : localtype*, ret_val : context, var_2 : context?}: + `%%%%`(v_context, var_0, var_1, ret_val) + -- wf_context: `%`(v_context) + -- (wf_uN: `%%`(32, var_0))*{var_0 <- var_0} + -- (wf_localtype: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = !(var_2)) + -- if (var_2 =/= ?()) + -- wf_context: `%`(ret_val) + -- fun_with_locals: `%%%%`(v_context, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rec { -;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.1-62.94 -def $clos_deftypes(var_0 : deftype*) : deftype* - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:71.1-71.30 - def $clos_deftypes([]) = [] - ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:72.1-72.101 - def $clos_deftypes{dt_lst : deftype*, dt_n : deftype}(dt_lst ++ [dt_n]) = dt'_lst ++ [$subst_all_deftype(dt_n, $typeuse_deftype(dt')*{dt' <- dt'_lst})] - -- let{dt'_lst : deftype*} dt'_lst = $clos_deftypes(dt_lst) +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 +relation fun_clos_deftypes: `%%`(deftype*, deftype*) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 + rule fun_clos_deftypes_case_1{dt_lst : deftype*, dt_n : deftype, var_1 : deftype*, var_0 : deftype}: + `%%`(dt_lst ++ [dt_n], dt'_lst ++ [var_0]) + -- let{dt'_lst : deftype*} dt'_lst = var_1 + -- fun_clos_deftypes: `%%`(dt_lst, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- dt'_lst}, var_0) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_valtype(v_context : context, v_valtype : valtype) : valtype +relation fun_clos_valtype: `%%%`(context, valtype, valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_valtype_case_0{C : context, t : valtype, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- let{dt_lst : deftype*} dt_lst = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation clos_valtype_is_wf: `%%%`(v_context : context, v_valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule clos_valtype_is_wf_0{v_context : context, v_valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(v_context, v_valtype, ret_val) + -- wf_context: `%`(v_context) + -- wf_valtype: `%`(v_valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_clos_valtype: `%%%`(v_context, v_valtype, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_deftype: `%%%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_valtype{C : context, t : valtype}(C, t) = $subst_all_valtype(t, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- let{dt_lst : deftype*} dt_lst = $clos_deftypes(C.TYPES_context) + rule fun_clos_deftype_case_0{C : context, dt : deftype, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- let{dt'_lst : deftype*} dt'_lst = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- dt'_lst}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(v_context : context, v_deftype : deftype) : deftype +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype}(C, dt) = $subst_all_deftype(dt, $typeuse_deftype(dt')*{dt' <- dt'_lst}) - -- let{dt'_lst : deftype*} dt'_lst = $clos_deftypes(C.TYPES_context) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- let{dt_lst : deftype*} dt_lst = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(v_context : context, v_tagtype : tagtype) : tagtype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse}(C, jt) = $subst_all_tagtype(jt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- let{dt_lst : deftype*} dt_lst = $clos_deftypes(C.TYPES_context) + rule fun_clos_externtype_case_0{C : context, xt : externtype, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- let{dt_lst : deftype*} dt_lst = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(v_context : context, v_externtype : externtype) : externtype +relation clos_externtype_is_wf: `%%%`(v_context : context, v_externtype : externtype, ret_val : externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype}(C, xt) = $subst_all_externtype(xt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- let{dt_lst : deftype*} dt_lst = $clos_deftypes(C.TYPES_context) + rule clos_externtype_is_wf_0{v_context : context, v_externtype : externtype, ret_val : externtype, var_0 : externtype}: + `%%%`(v_context, v_externtype, ret_val) + -- wf_context: `%`(v_context) + -- wf_externtype: `%`(v_externtype) + -- if (ret_val = var_0) + -- wf_externtype: `%`(ret_val) + -- fun_clos_externtype: `%%%`(v_context, v_externtype, var_0) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- let{dt_lst : deftype*} dt_lst = var_1 + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(v_context : context, v_moduletype : moduletype) : moduletype +relation clos_moduletype_is_wf: `%%%`(v_context : context, v_moduletype : moduletype, ret_val : moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype}(C, mmt) = $subst_all_moduletype(mmt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- let{dt_lst : deftype*} dt_lst = $clos_deftypes(C.TYPES_context) + rule clos_moduletype_is_wf_0{v_context : context, v_moduletype : moduletype, ret_val : moduletype, var_0 : moduletype}: + `%%%`(v_context, v_moduletype, ret_val) + -- wf_context: `%`(v_context) + -- wf_moduletype: `%`(v_moduletype) + -- if (ret_val = var_0) + -- wf_moduletype: `%`(ret_val) + -- fun_clos_moduletype: `%%%`(v_context, v_moduletype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -5309,10 +7117,12 @@ relation Numtype_sub: `%|-%<:%`(context, numtype, numtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Expand: `%~~%`(deftype, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule mk_Expand{v_deftype : deftype, v_comptype : comptype, final_opt : final?, typeuse_lst : typeuse*}: + rule mk_Expand{v_deftype : deftype, v_comptype : comptype, final_opt : final?, typeuse_lst : typeuse*, var_0 : subtype}: `%~~%`(v_deftype, v_comptype) - -- if ($unrolldt(v_deftype) = SUB_subtype(final_opt, typeuse_lst, v_comptype)) + -- if (var_0 = SUB_subtype(final_opt, typeuse_lst, v_comptype)) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final_opt, typeuse_lst, v_comptype)) + -- fun_unrolldt: `%%`(v_deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5329,13 +7139,33 @@ def $before(v_typeuse : typeuse, nat : nat) : bool def $before{v_typeuse : typeuse, i : nat}(v_typeuse, i) = true ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec -def $unrollht_(v_context : context, v_heaptype : heaptype) : subtype +relation fun_unrollht_: `%%%`(context, heaptype, subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{v_rectype : rectype, v_n : n, C : context}(C, _DEF_heaptype(v_rectype, v_n)) = $unrolldt(_DEF_deftype(v_rectype, v_n)) + rule fun_unrollht__case_0{v_rectype : rectype, v_n : n, C : context, var_0 : subtype}: + `%%%`(C, _DEF_heaptype(v_rectype, v_n), var_0) + -- fun_unrolldt: `%%`(_DEF_deftype(v_rectype, v_n), var_0) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule fun_unrollht__case_1{C : context, v_typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(v_typeidx), var_0) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(v_typeidx).0], var_0) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, v_typeidx : uN}(C, _IDX_heaptype(v_typeidx)) = $unrolldt(C.TYPES_context[$proj_uN_0(v_typeidx).0]) + rule fun_unrollht__case_2{C : context, i : nat}: + `%%%`(C, REC_heaptype(i), C.RECS_context[i]) + -- if (i < |C.RECS_context|) + +;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec +relation unrollht__is_wf: `%%%`(v_context : context, v_heaptype : heaptype, ret_val : subtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + rule unrollht__is_wf_0{v_context : context, v_heaptype : heaptype, ret_val : subtype, var_0 : subtype}: + `%%%`(v_context, v_heaptype, ret_val) + -- wf_context: `%`(v_context) + -- wf_heaptype: `%`(v_heaptype) + -- if (ret_val = var_0) + -- wf_subtype: `%`(ret_val) + -- fun_unrollht_: `%%%`(v_context, v_heaptype, var_0) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5401,16 +7231,16 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:106.1-108.30 rule typeidx{C : context, v_typeidx : typeidx, dt : deftype}: `%|-%:OK`(C, _IDX_typeuse(v_typeidx)) - -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(v_typeidx).0] = dt) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(v_typeidx)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 rule rec{C : context, i : n, st : subtype}: `%|-%:OK`(C, REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) @@ -5425,7 +7255,7 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) relation Resulttype_ok: `%|-%:OK`(context, resulttype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:60.1-62.32 rule mk_Resulttype_ok{C : context, t_lst : valtype*}: - `%|-%:OK`(C, `%`_resulttype(t_lst)) + `%|-%:OK`(C, mk_list_resulttype(t_lst)) -- (Valtype_ok: `%|-%:OK`(C, t))*{t <- t_lst} -- wf_context: `%`(C) -- (wf_valtype: `%`(t))*{t <- t_lst} @@ -5434,10 +7264,10 @@ relation Resulttype_ok: `%|-%:OK`(context, resulttype) relation Fieldtype_ok: `%|-%:OK`(context, fieldtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:130.1-132.43 rule mk_Fieldtype_ok{C : context, v_storagetype : storagetype}: - `%|-%:OK`(C, `%%`_fieldtype(?(MUT_mut), v_storagetype)) + `%|-%:OK`(C, mk_fieldtype_fieldtype(?(MUT_mut), v_storagetype)) -- Storagetype_ok: `%|-%:OK`(C, v_storagetype) -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), v_storagetype)) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(MUT_mut), v_storagetype)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:93.1-93.106 relation Storagetype_ok: `%|-%:OK`(context, storagetype) @@ -5458,10 +7288,10 @@ relation Storagetype_ok: `%|-%:OK`(context, storagetype) relation Comptype_ok: `%|-%:OK`(context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:135.1-137.42 rule struct{C : context, fieldtype_lst : fieldtype*}: - `%|-%:OK`(C, STRUCT_comptype(`%`_list(fieldtype_lst))) + `%|-%:OK`(C, STRUCT_comptype(mk_list_list(fieldtype_lst))) -- (Fieldtype_ok: `%|-%:OK`(C, v_fieldtype))*{v_fieldtype <- fieldtype_lst} -- wf_context: `%`(C) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype_lst))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(fieldtype_lst))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:139.1-141.39 rule array{C : context, v_fieldtype : fieldtype}: @@ -5472,41 +7302,45 @@ relation Comptype_ok: `%|-%:OK`(context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:143.1-146.35 rule func{C : context, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:OK`(C, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1_lst)) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2_lst)) + `%|-%:OK`(C, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_1_lst)) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_2_lst)) -- wf_context: `%`(C) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:97.1-97.126 relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:167.1-176.49 - rule mk_Subtype_ok2{C : context, typeuse_lst : typeuse*, v_comptype : comptype, i : nat, comptype'_lst : comptype*, typeuse'_lst_lst : typeuse**}: + rule mk_Subtype_ok2{C : context, typeuse_lst : typeuse*, v_comptype : comptype, i : nat, comptype'_lst : comptype*, typeuse'_lst_lst : typeuse**, var_0_lst : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse_lst, v_comptype), OK_oktypenat(i)) -- if (|typeuse_lst| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, v_typeuse))*{v_typeuse <- typeuse_lst} -- (if $before(v_typeuse, i))*{v_typeuse <- typeuse_lst} - -- if (|comptype'_lst| = |typeuse_lst|) - -- if (|comptype'_lst| = |typeuse'_lst_lst|) - -- (if ($unrollht_(C, $heaptype_typeuse(v_typeuse)) = SUB_subtype(?(), typeuse'_lst, comptype')))*{comptype' <- comptype'_lst, v_typeuse <- typeuse_lst, typeuse'_lst <- typeuse'_lst_lst} + -- (if (var_0 = SUB_subtype(?(), typeuse'_lst, comptype')))*{var_0 <- var_0_lst, comptype' <- comptype'_lst, typeuse'_lst <- typeuse'_lst_lst} + -- if (|var_0_lst| = |comptype'_lst|) + -- if (|var_0_lst| = |typeuse'_lst_lst|) -- Comptype_ok: `%|-%:OK`(C, v_comptype) -- (Comptype_sub: `%|-%<:%`(C, v_comptype, comptype'))*{comptype' <- comptype'_lst} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- var_0_lst} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse_lst, v_comptype)) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'_lst, comptype')))*{comptype' <- comptype'_lst, typeuse'_lst <- typeuse'_lst_lst} + -- if (|comptype'_lst| = |typeuse'_lst_lst|) + -- (fun_unrollht_: `%%%`(C, $heaptype_typeuse(v_typeuse), var_0))*{var_0 <- var_0_lst, v_typeuse <- typeuse_lst} + -- if (|var_0_lst| = |typeuse_lst|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:188.1-189.23 rule empty{C : context, i : nat}: - `%|-%:%`(C, REC_rectype(`%`_list([])), OK_oktypenat(i)) + `%|-%:%`(C, REC_rectype(mk_list_list([])), OK_oktypenat(i)) -- wf_context: `%`(C) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:191.1-194.49 rule cons{C : context, subtype_1 : subtype, subtype_lst : subtype*, i : nat}: - `%|-%:%`(C, REC_rectype(`%`_list([subtype_1] ++ subtype_lst)), OK_oktypenat(i)) + `%|-%:%`(C, REC_rectype(mk_list_list([subtype_1] ++ subtype_lst)), OK_oktypenat(i)) -- Subtype_ok2: `%|-%:%`(C, subtype_1, OK_oktypenat(i)) - -- Rectype_ok2: `%|-%:%`(C, REC_rectype(`%`_list(subtype_lst)), OK_oktypenat((i + 1))) + -- Rectype_ok2: `%|-%:%`(C, REC_rectype(mk_list_list(subtype_lst)), OK_oktypenat((i + 1))) -- wf_context: `%`(C) -- wf_subtype: `%`(subtype_1) -- (wf_subtype: `%`(v_subtype))*{v_subtype <- subtype_lst} @@ -5517,21 +7351,22 @@ relation Deftype_ok: `%|-%:OK`(context, deftype) rule mk_Deftype_ok{C : context, v_rectype : rectype, i : n, v_n : n, subtype_lst : subtype*}: `%|-%:OK`(C, _DEF_deftype(v_rectype, i)) -- Rectype_ok2: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype_lst} +++ C, v_rectype, OK_oktypenat(0)) - -- if (v_rectype = REC_rectype(`%`_list(subtype_lst))) + -- if (v_rectype = REC_rectype(mk_list_list(subtype_lst))) -- if (i < v_n) -- wf_context: `%`(C) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype_lst}) + -- if (v_n = |subtype_lst|) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:102.1-102.108 relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:181.1-183.41 rule struct{C : context, ft_1_lst : fieldtype*, ft'_1_lst : fieldtype*, ft_2_lst : fieldtype*}: - `%|-%<:%`(C, STRUCT_comptype(`%`_list(ft_1_lst ++ ft'_1_lst)), STRUCT_comptype(`%`_list(ft_2_lst))) - -- if (|ft_1_lst| = |ft_2_lst|) + `%|-%<:%`(C, STRUCT_comptype(mk_list_list(ft_1_lst ++ ft'_1_lst)), STRUCT_comptype(mk_list_list(ft_2_lst))) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- ft_1_lst, ft_2 <- ft_2_lst} + -- if (|ft_1_lst| = |ft_2_lst|) -- wf_context: `%`(C) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_1_lst ++ ft'_1_lst))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_2_lst))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(ft_1_lst ++ ft'_1_lst))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(ft_2_lst))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:185.1-187.38 rule array{C : context, ft_1 : fieldtype, ft_2 : fieldtype}: @@ -5543,29 +7378,33 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:189.1-192.41 rule func{C : context, t_11_lst : valtype*, t_12_lst : valtype*, t_21_lst : valtype*, t_22_lst : valtype*}: - `%|-%<:%`(C, `FUNC%->%`_comptype(`%`_resulttype(t_11_lst), `%`_resulttype(t_12_lst)), `FUNC%->%`_comptype(`%`_resulttype(t_21_lst), `%`_resulttype(t_22_lst))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21_lst), `%`_resulttype(t_11_lst)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12_lst), `%`_resulttype(t_22_lst)) + `%|-%<:%`(C, `FUNC%->%`_comptype(mk_list_resulttype(t_11_lst), mk_list_resulttype(t_12_lst)), `FUNC%->%`_comptype(mk_list_resulttype(t_21_lst), mk_list_resulttype(t_22_lst))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_21_lst), mk_list_resulttype(t_11_lst)) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_12_lst), mk_list_resulttype(t_22_lst)) -- wf_context: `%`(C) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_11_lst), `%`_resulttype(t_12_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_21_lst), `%`_resulttype(t_22_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_11_lst), mk_list_resulttype(t_12_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_21_lst), mk_list_resulttype(t_22_lst))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:103.1-103.107 relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:195.1-197.66 - rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype}: + rule refl{C : context, deftype_1 : deftype, deftype_2 : deftype, var_1 : deftype, var_0 : deftype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) -- wf_context: `%`(C) + -- fun_clos_deftype: `%%%`(C, deftype_2, var_1) + -- fun_clos_deftype: `%%%`(C, deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:199.1-202.49 - rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, final_opt : final?, typeuse_lst : typeuse*, ct : comptype, i : nat}: + rule super{C : context, deftype_1 : deftype, deftype_2 : deftype, final_opt : final?, typeuse_lst : typeuse*, ct : comptype, i : nat, var_0 : subtype}: `%|-%<:%`(C, deftype_1, deftype_2) - -- if ($unrolldt(deftype_1) = SUB_subtype(final_opt, typeuse_lst, ct)) - -- if (i < |typeuse_lst|) + -- if (var_0 = SUB_subtype(final_opt, typeuse_lst, ct)) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse_lst[i]), $heaptype_deftype(deftype_2)) + -- if (i < |typeuse_lst|) -- wf_context: `%`(C) + -- wf_subtype: `%`(var_0) -- wf_subtype: `%`(SUB_subtype(final_opt, typeuse_lst, ct)) + -- fun_unrolldt: `%%`(deftype_1, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) @@ -5617,10 +7456,10 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:41.1-43.42 rule struct{C : context, v_deftype : deftype, fieldtype_lst : fieldtype*}: `%|-%<:%`(C, $heaptype_deftype(v_deftype), STRUCT_heaptype) - -- Expand: `%~~%`(v_deftype, STRUCT_comptype(`%`_list(fieldtype_lst))) + -- Expand: `%~~%`(v_deftype, STRUCT_comptype(mk_list_list(fieldtype_lst))) -- wf_context: `%`(C) -- wf_heaptype: `%`(STRUCT_heaptype) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype_lst))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(fieldtype_lst))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:45.1-47.40 rule array{C : context, v_deftype : deftype, v_fieldtype : fieldtype}: @@ -5633,10 +7472,10 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:49.1-51.42 rule func{C : context, v_deftype : deftype, t_1_lst : valtype*, t_2_lst : valtype*}: `%|-%<:%`(C, $heaptype_deftype(v_deftype), FUNC_heaptype) - -- Expand: `%~~%`(v_deftype, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- Expand: `%~~%`(v_deftype, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_heaptype: `%`(FUNC_heaptype) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:53.1-55.46 rule def{C : context, deftype_1 : deftype, deftype_2 : deftype}: @@ -5647,8 +7486,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:57.1-59.53 rule typeidx_l{C : context, v_typeidx : typeidx, v_heaptype : heaptype}: `%|-%<:%`(C, _IDX_heaptype(v_typeidx), v_heaptype) - -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(v_typeidx).0]), v_heaptype) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(v_heaptype) -- wf_heaptype: `%`(_IDX_heaptype(v_typeidx)) @@ -5656,8 +7495,8 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule typeidx_r{C : context, v_heaptype : heaptype, v_typeidx : typeidx}: `%|-%<:%`(C, v_heaptype, _IDX_heaptype(v_typeidx)) - -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, v_heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(v_typeidx).0])) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(v_heaptype) -- wf_heaptype: `%`(_IDX_heaptype(v_typeidx)) @@ -5665,18 +7504,18 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule rec_struct{C : context, i : n, final_opt : final?, fieldtype_lst : fieldtype*}: `%|-%<:%`(C, REC_heaptype(i), STRUCT_heaptype) + -- if (C.RECS_context[i] = SUB_subtype(final_opt, [], STRUCT_comptype(mk_list_list(fieldtype_lst)))) -- if (i < |C.RECS_context|) - -- if (C.RECS_context[i] = SUB_subtype(final_opt, [], STRUCT_comptype(`%`_list(fieldtype_lst)))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) - -- wf_subtype: `%`(SUB_subtype(final_opt, [], STRUCT_comptype(`%`_list(fieldtype_lst)))) + -- wf_subtype: `%`(SUB_subtype(final_opt, [], STRUCT_comptype(mk_list_list(fieldtype_lst)))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 rule rec_array{C : context, i : n, final_opt : final?, v_fieldtype : fieldtype}: `%|-%<:%`(C, REC_heaptype(i), ARRAY_heaptype) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final_opt, [], ARRAY_comptype(v_fieldtype))) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) @@ -5685,22 +7524,22 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 rule rec_func{C : context, i : n, final_opt : final?, t_1_lst : valtype*, t_2_lst : valtype*}: `%|-%<:%`(C, REC_heaptype(i), FUNC_heaptype) + -- if (C.RECS_context[i] = SUB_subtype(final_opt, [], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)))) -- if (i < |C.RECS_context|) - -- if (C.RECS_context[i] = SUB_subtype(final_opt, [], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)))) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(FUNC_heaptype) - -- wf_subtype: `%`(SUB_subtype(final_opt, [], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)))) + -- wf_subtype: `%`(SUB_subtype(final_opt, [], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:77.1-79.43 rule rec_sub{C : context, i : n, typeuse_lst : typeuse*, j : nat, final_opt : final?, ct : comptype}: `%|-%<:%`(C, REC_heaptype(i), $heaptype_typeuse(typeuse_lst[j])) - -- if (j < |typeuse_lst|) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final_opt, typeuse_lst, ct)) + -- if (i < |C.RECS_context|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final_opt, typeuse_lst, ct)) + -- if (j < |typeuse_lst|) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 rule none{C : context, v_heaptype : heaptype}: @@ -5804,9 +7643,9 @@ relation Valtype_sub: `%|-%<:%`(context, valtype, valtype) relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:135.1-137.37 rule mk_Resulttype_sub{C : context, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%<:%`(C, `%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)) - -- if (|t_1_lst| = |t_2_lst|) + `%|-%<:%`(C, mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)) -- (Valtype_sub: `%|-%<:%`(C, t_1, t_2))*{t_1 <- t_1_lst, t_2 <- t_2_lst} + -- if (|t_1_lst| = |t_2_lst|) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- t_1_lst} -- (wf_valtype: `%`(t_2))*{t_2 <- t_2_lst} @@ -5831,44 +7670,44 @@ relation Storagetype_sub: `%|-%<:%`(context, storagetype, storagetype) relation Fieldtype_sub: `%|-%<:%`(context, fieldtype, fieldtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:171.1-173.40 rule const{C : context, zt_1 : storagetype, zt_2 : storagetype}: - `%|-%<:%`(C, `%%`_fieldtype(?(), zt_1), `%%`_fieldtype(?(), zt_2)) + `%|-%<:%`(C, mk_fieldtype_fieldtype(?(), zt_1), mk_fieldtype_fieldtype(?(), zt_2)) -- Storagetype_sub: `%|-%<:%`(C, zt_1, zt_2) -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_1)) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_2)) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(), zt_1)) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(), zt_2)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:175.1-178.40 rule var{C : context, zt_1 : storagetype, zt_2 : storagetype}: - `%|-%<:%`(C, `%%`_fieldtype(?(MUT_mut), zt_1), `%%`_fieldtype(?(MUT_mut), zt_2)) + `%|-%<:%`(C, mk_fieldtype_fieldtype(?(MUT_mut), zt_1), mk_fieldtype_fieldtype(?(MUT_mut), zt_2)) -- Storagetype_sub: `%|-%<:%`(C, zt_1, zt_2) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_1)) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_2)) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(MUT_mut), zt_1)) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(MUT_mut), zt_2)) } ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Localtype_ok: `%|-%:OK`(context, localtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule mk_Localtype_ok{C : context, v_init : init, t : valtype}: - `%|-%:OK`(C, `%%`_localtype(v_init, t)) + `%|-%:OK`(C, mk_localtype_localtype(v_init, t)) -- Valtype_ok: `%|-%:OK`(C, t) -- wf_context: `%`(C) - -- wf_localtype: `%`(`%%`_localtype(v_init, t)) + -- wf_localtype: `%`(mk_localtype_localtype(v_init, t)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Instrtype_ok: `%|-%:OK`(context, instrtype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule mk_Instrtype_ok{C : context, t_1_lst : valtype*, x_lst : idx*, t_2_lst : valtype*, lct_lst : localtype*}: - `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_1_lst)) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_2_lst)) + `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_1_lst)) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_2_lst)) + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- lct_lst, x <- x_lst} -- if (|lct_lst| = |x_lst|) -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- x_lst} - -- (if (C.LOCALS_context[$proj_uN_0(x).0] = lct))*{lct <- lct_lst, x <- x_lst} -- wf_context: `%`(C) -- (wf_localtype: `%`(lct))*{lct <- lct_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Expand_use: `%~~_%%`(typeuse, context, comptype) @@ -5882,8 +7721,8 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule typeidx{v_typeidx : typeidx, C : context, v_comptype : comptype}: `%~~_%%`(_IDX_typeuse(v_typeidx), C, v_comptype) - -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(v_typeidx).0], v_comptype) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) -- wf_context: `%`(C) -- wf_comptype: `%`(v_comptype) -- wf_typeuse: `%`(_IDX_typeuse(v_typeidx)) @@ -5902,20 +7741,24 @@ relation wf_oktypeidx: `%`(oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - rule mk_Subtype_ok{C : context, x_lst : idx*, v_comptype : comptype, x_0 : idx, comptype'_lst : comptype*, yy_lst_lst : typeuse**}: + rule mk_Subtype_ok{C : context, x_lst : idx*, v_comptype : comptype, x_0 : idx, comptype'_lst : comptype*, yy_lst_lst : typeuse**, var_0_lst : subtype*}: `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- x_lst}, v_comptype), OK_oktypeidx(x_0)) -- if (|x_lst| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- x_lst} - -- if (|comptype'_lst| = |x_lst|) - -- if (|comptype'_lst| = |yy_lst_lst|) - -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- x_lst} - -- (if ($unrolldt(C.TYPES_context[$proj_uN_0(x).0]) = SUB_subtype(?(), yy_lst, comptype')))*{comptype' <- comptype'_lst, x <- x_lst, yy_lst <- yy_lst_lst} + -- (if (var_0 = SUB_subtype(?(), yy_lst, comptype')))*{var_0 <- var_0_lst, comptype' <- comptype'_lst, yy_lst <- yy_lst_lst} + -- if (|var_0_lst| = |comptype'_lst|) + -- if (|var_0_lst| = |yy_lst_lst|) -- Comptype_ok: `%|-%:OK`(C, v_comptype) -- (Comptype_sub: `%|-%<:%`(C, v_comptype, comptype'))*{comptype' <- comptype'_lst} -- wf_context: `%`(C) + -- (wf_subtype: `%`(var_0))*{var_0 <- var_0_lst} -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- x_lst}, v_comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) -- (wf_subtype: `%`(SUB_subtype(?(), yy_lst, comptype')))*{comptype' <- comptype'_lst, yy_lst <- yy_lst_lst} + -- if (|comptype'_lst| = |yy_lst_lst|) + -- (fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(x).0], var_0))*{var_0 <- var_0_lst, x <- x_lst} + -- if (|var_0_lst| = |x_lst|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- x_lst} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -5924,31 +7767,31 @@ rec { relation Rectype_ok: `%|-%:%`(context, rectype, oktypeidx) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:179.1-180.23 rule empty{C : context, x : idx}: - `%|-%:%`(C, REC_rectype(`%`_list([])), OK_oktypeidx(x)) + `%|-%:%`(C, REC_rectype(mk_list_list([])), OK_oktypeidx(x)) -- wf_context: `%`(C) -- wf_oktypeidx: `%`(OK_oktypeidx(x)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:182.1-185.48 rule cons{C : context, subtype_1 : subtype, subtype_lst : subtype*, x : idx}: - `%|-%:%`(C, REC_rectype(`%`_list([subtype_1] ++ subtype_lst)), OK_oktypeidx(x)) + `%|-%:%`(C, REC_rectype(mk_list_list([subtype_1] ++ subtype_lst)), OK_oktypeidx(x)) -- Subtype_ok: `%|-%:%`(C, subtype_1, OK_oktypeidx(x)) - -- Rectype_ok: `%|-%:%`(C, REC_rectype(`%`_list(subtype_lst)), OK_oktypeidx(`%`_typeidx(($proj_uN_0(x).0 + 1)))) + -- Rectype_ok: `%|-%:%`(C, REC_rectype(mk_list_list(subtype_lst)), OK_oktypeidx(mk_uN_typeidx(($proj_uN_0(x).0 + 1)))) -- wf_context: `%`(C) -- wf_subtype: `%`(subtype_1) -- (wf_subtype: `%`(v_subtype))*{v_subtype <- subtype_lst} -- wf_oktypeidx: `%`(OK_oktypeidx(x)) - -- wf_oktypeidx: `%`(OK_oktypeidx(`%`_typeidx(($proj_uN_0(x).0 + 1)))) + -- wf_oktypeidx: `%`(OK_oktypeidx(mk_uN_typeidx(($proj_uN_0(x).0 + 1)))) } ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Limits_ok: `%|-%:%`(context, limits, nat) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule mk_Limits_ok{C : context, v_n : n, m_opt : m?, k : nat}: - `%|-%:%`(C, `[%..%]`_limits(`%`_u64(v_n), `%`_u64(v_m)?{v_m <- m_opt}), k) + `%|-%:%`(C, mk_limits_limits(mk_uN_u64(v_n), mk_uN_u64(v_m)?{v_m <- m_opt}), k) -- if (v_n <= k) -- (if ((v_n <= v_m) /\ (v_m <= k)))?{v_m <- m_opt} -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(v_n), `%`_u64(v_m)?{v_m <- m_opt})) + -- wf_limits: `%`(mk_limits_limits(mk_uN_u64(v_n), mk_uN_u64(v_m)?{v_m <- m_opt})) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Tagtype_ok: `%|-%:OK`(context, tagtype) @@ -5956,19 +7799,19 @@ relation Tagtype_ok: `%|-%:OK`(context, tagtype) rule mk_Tagtype_ok{C : context, v_typeuse : typeuse, t_1_lst : valtype*, t_2_lst : valtype*}: `%|-%:OK`(C, v_typeuse) -- Typeuse_ok: `%|-%:OK`(C, v_typeuse) - -- Expand_use: `%~~_%%`(v_typeuse, C, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- Expand_use: `%~~_%%`(v_typeuse, C, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_typeuse: `%`(v_typeuse) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Globaltype_ok: `%|-%:OK`(context, globaltype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule mk_Globaltype_ok{C : context, t : valtype}: - `%|-%:OK`(C, `%%`_globaltype(?(MUT_mut), t)) + `%|-%:OK`(C, mk_globaltype_globaltype(?(MUT_mut), t)) -- Valtype_ok: `%|-%:OK`(C, t) -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(MUT_mut), t)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Memtype_ok: `%|-%:OK`(context, memtype) @@ -5983,11 +7826,11 @@ relation Memtype_ok: `%|-%:OK`(context, memtype) relation Tabletype_ok: `%|-%:OK`(context, tabletype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rule mk_Tabletype_ok{C : context, v_addrtype : addrtype, v_limits : limits, v_reftype : reftype}: - `%|-%:OK`(C, `%%%`_tabletype(v_addrtype, v_limits, v_reftype)) + `%|-%:OK`(C, mk_tabletype_tabletype(v_addrtype, v_limits, v_reftype)) -- Limits_ok: `%|-%:%`(C, v_limits, ((((2 ^ $size($numtype_addrtype(v_addrtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) -- Reftype_ok: `%|-%:OK`(C, v_reftype) -- wf_context: `%`(C) - -- wf_tabletype: `%`(`%%%`_tabletype(v_addrtype, v_limits, v_reftype)) + -- wf_tabletype: `%`(mk_tabletype_tabletype(v_addrtype, v_limits, v_reftype)) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Externtype_ok: `%|-%:OK`(context, externtype) @@ -6023,46 +7866,47 @@ relation Externtype_ok: `%|-%:OK`(context, externtype) rule func{C : context, v_typeuse : typeuse, t_1_lst : valtype*, t_2_lst : valtype*}: `%|-%:OK`(C, FUNC_externtype(v_typeuse)) -- Typeuse_ok: `%|-%:OK`(C, v_typeuse) - -- Expand_use: `%~~_%%`(v_typeuse, C, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- Expand_use: `%~~_%%`(v_typeuse, C, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_externtype: `%`(FUNC_externtype(v_typeuse)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Instrtype_sub: `%|-%<:%`(context, instrtype, instrtype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule mk_Instrtype_sub{C : context, t_11_lst : valtype*, x_1_lst : idx*, t_12_lst : valtype*, t_21_lst : valtype*, x_2_lst : idx*, t_22_lst : valtype*, x_lst : idx*, t_lst : valtype*}: - `%|-%<:%`(C, `%->_%%`_instrtype(`%`_resulttype(t_11_lst), x_1_lst, `%`_resulttype(t_12_lst)), `%->_%%`_instrtype(`%`_resulttype(t_21_lst), x_2_lst, `%`_resulttype(t_22_lst))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_21_lst), `%`_resulttype(t_11_lst)) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_12_lst), `%`_resulttype(t_22_lst)) + `%|-%<:%`(C, mk_instrtype_instrtype(mk_list_resulttype(t_11_lst), x_1_lst, mk_list_resulttype(t_12_lst)), mk_instrtype_instrtype(mk_list_resulttype(t_21_lst), x_2_lst, mk_list_resulttype(t_22_lst))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_21_lst), mk_list_resulttype(t_11_lst)) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_12_lst), mk_list_resulttype(t_22_lst)) -- if (x_lst = $setminus_(syntax localidx, x_2_lst, x_1_lst)) + -- (if (C.LOCALS_context[$proj_uN_0(x).0] = mk_localtype_localtype(SET_init, t)))*{t <- t_lst, x <- x_lst} -- if (|t_lst| = |x_lst|) -- (if ($proj_uN_0(x).0 < |C.LOCALS_context|))*{x <- x_lst} - -- (if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)))*{t <- t_lst, x <- x_lst} -- wf_context: `%`(C) -- (wf_uN: `%%`(32, x))*{x <- x_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_11_lst), x_1_lst, `%`_resulttype(t_12_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_21_lst), x_2_lst, `%`_resulttype(t_22_lst))) - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- t_lst} + -- (wf_uN: `%%`(32, iter))*{iter <- $setminus_(syntax localidx, x_2_lst, x_1_lst)} + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_11_lst), x_1_lst, mk_list_resulttype(t_12_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_21_lst), x_2_lst, mk_list_resulttype(t_22_lst))) + -- (wf_localtype: `%`(mk_localtype_localtype(SET_init, t)))*{t <- t_lst} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Limits_sub: `%|-%<:%`(context, limits, limits) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule max{C : context, n_1 : n, m_1 : m, n_2 : n, m_2_opt : m?}: - `%|-%<:%`(C, `[%..%]`_limits(`%`_u64(n_1), ?(`%`_u64(m_1))), `[%..%]`_limits(`%`_u64(n_2), `%`_u64(m_2)?{m_2 <- m_2_opt})) + `%|-%<:%`(C, mk_limits_limits(mk_uN_u64(n_1), ?(mk_uN_u64(m_1))), mk_limits_limits(mk_uN_u64(n_2), mk_uN_u64(m_2)?{m_2 <- m_2_opt})) -- if (n_1 >= n_2) -- (if (m_1 <= m_2))?{m_2 <- m_2_opt} -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_1), ?(`%`_u64(m_1)))) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_2), `%`_u64(m_2)?{m_2 <- m_2_opt})) + -- wf_limits: `%`(mk_limits_limits(mk_uN_u64(n_1), ?(mk_uN_u64(m_1)))) + -- wf_limits: `%`(mk_limits_limits(mk_uN_u64(n_2), mk_uN_u64(m_2)?{m_2 <- m_2_opt})) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule eps{C : context, n_1 : n, n_2 : n}: - `%|-%<:%`(C, `[%..%]`_limits(`%`_u64(n_1), ?()), `[%..%]`_limits(`%`_u64(n_2), ?())) + `%|-%<:%`(C, mk_limits_limits(mk_uN_u64(n_1), ?()), mk_limits_limits(mk_uN_u64(n_2), ?())) -- if (n_1 >= n_2) -- wf_context: `%`(C) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_1), ?())) - -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_2), ?())) + -- wf_limits: `%`(mk_limits_limits(mk_uN_u64(n_1), ?())) + -- wf_limits: `%`(mk_limits_limits(mk_uN_u64(n_2), ?())) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Tagtype_sub: `%|-%<:%`(context, tagtype, tagtype) @@ -6077,20 +7921,20 @@ relation Tagtype_sub: `%|-%<:%`(context, tagtype, tagtype) relation Globaltype_sub: `%|-%<:%`(context, globaltype, globaltype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule const{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, `%%`_globaltype(?(), valtype_1), `%%`_globaltype(?(), valtype_2)) + `%|-%<:%`(C, mk_globaltype_globaltype(?(), valtype_1), mk_globaltype_globaltype(?(), valtype_2)) -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_1)) - -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_2)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(), valtype_1)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(), valtype_2)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule var{C : context, valtype_1 : valtype, valtype_2 : valtype}: - `%|-%<:%`(C, `%%`_globaltype(?(MUT_mut), valtype_1), `%%`_globaltype(?(MUT_mut), valtype_2)) + `%|-%<:%`(C, mk_globaltype_globaltype(?(MUT_mut), valtype_1), mk_globaltype_globaltype(?(MUT_mut), valtype_2)) -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) -- Valtype_sub: `%|-%<:%`(C, valtype_2, valtype_1) -- wf_context: `%`(C) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_1)) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_2)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(MUT_mut), valtype_1)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(MUT_mut), valtype_2)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Memtype_sub: `%|-%<:%`(context, memtype, memtype) @@ -6106,13 +7950,13 @@ relation Memtype_sub: `%|-%<:%`(context, memtype, memtype) relation Tabletype_sub: `%|-%<:%`(context, tabletype, tabletype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec rule mk_Tabletype_sub{C : context, v_addrtype : addrtype, limits_1 : limits, reftype_1 : reftype, limits_2 : limits, reftype_2 : reftype}: - `%|-%<:%`(C, `%%%`_tabletype(v_addrtype, limits_1, reftype_1), `%%%`_tabletype(v_addrtype, limits_2, reftype_2)) + `%|-%<:%`(C, mk_tabletype_tabletype(v_addrtype, limits_1, reftype_1), mk_tabletype_tabletype(v_addrtype, limits_2, reftype_2)) -- Limits_sub: `%|-%<:%`(C, limits_1, limits_2) -- Reftype_sub: `%|-%<:%`(C, reftype_1, reftype_2) -- Reftype_sub: `%|-%<:%`(C, reftype_2, reftype_1) -- wf_context: `%`(C) - -- wf_tabletype: `%`(`%%%`_tabletype(v_addrtype, limits_1, reftype_1)) - -- wf_tabletype: `%`(`%%%`_tabletype(v_addrtype, limits_2, reftype_2)) + -- wf_tabletype: `%`(mk_tabletype_tabletype(v_addrtype, limits_1, reftype_1)) + -- wf_tabletype: `%`(mk_tabletype_tabletype(v_addrtype, limits_2, reftype_2)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Externtype_sub: `%|-%<:%`(context, externtype, externtype) @@ -6160,106 +8004,111 @@ relation Externtype_sub: `%|-%<:%`(context, externtype, externtype) relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule valtype{C : context, valtype_opt : valtype?}: - `%|-%:%`(C, _RESULT_blocktype(valtype_opt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(valtype_opt)))) + `%|-%:%`(C, _RESULT_blocktype(valtype_opt), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(lift(valtype_opt)))) -- (Valtype_ok: `%|-%:OK`(C, v_valtype))?{v_valtype <- valtype_opt} -- wf_context: `%`(C) -- wf_blocktype: `%`(_RESULT_blocktype(valtype_opt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(valtype_opt)))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(lift(valtype_opt)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule typeidx{C : context, v_typeidx : typeidx, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, _IDX_blocktype(v_typeidx), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, _IDX_blocktype(v_typeidx), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(v_typeidx).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(v_typeidx).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_blocktype: `%`(_IDX_blocktype(v_typeidx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Catch_ok: `%|-%:OK`(context, catch) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch{C : context, x : idx, l : labelidx, t_lst : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_ref{C : context, x : idx, l : labelidx, t_lst : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_lst ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_catch(l)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all_ref{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_ALL_REF_catch(l)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(v_valtype : valtype) : val?? ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, `%`_uN(0)))) + def $default_(I32_valtype) = ?(?(CONST_val($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, mk_uN_uN(0))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0))))) - -- wf_val: `%`(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, `%`_uN(0)))) + def $default_(I64_valtype) = ?(?(CONST_val($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, mk_uN_uN(0))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F32_valtype) = ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_(F64_valtype) = ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))))) - -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) - -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) + def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, mk_uN_vec_(0)))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(`REF.NULL_ADDR`_val)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) + def $default_{ht : heaptype}(REF_valtype(?(NULL_null), ht)) = ?(?(REF_NULL_ADDR_val)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec def $default_{ht : heaptype}(REF_valtype(?(), ht)) = ?(?()) def $default_{x0 : valtype}(x0) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation default__is_wf: `%%`(v_valtype : valtype, ret_val : val?) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule default__is_wf_0{v_valtype : valtype, ret_val : val?}: + `%%`(v_valtype, ret_val) + -- wf_valtype: `%`(v_valtype) + -- if (ret_val = !($default_(v_valtype))) + -- if ($default_(v_valtype) =/= ?()) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Defaultable: `|-%DEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule mk_Defaultable{t : valtype}: `|-%DEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule mk_Memarg_ok{v_n : n, v_m : m, at : addrtype, v_N : N}: - `|-%:%->%`({ALIGN `%`_u32(v_n), OFFSET `%`_u64(v_m)}, at, v_N) + `|-%:%->%`({ALIGN mk_uN_u32(v_n), OFFSET mk_uN_u64(v_m)}, at, v_N) -- if (((2 ^ v_n) : nat <:> rat) <= ((v_N : nat <:> rat) / (8 : nat <:> rat))) -- if (v_m < (2 ^ $size($numtype_addrtype(at)))) - -- wf_memarg: `%`({ALIGN `%`_u32(v_n), OFFSET `%`_u64(v_m)}) + -- wf_memarg: `%`({ALIGN mk_uN_u32(v_n), OFFSET mk_uN_u64(v_m)}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec def $is_packtype(v_storagetype : storagetype) : bool @@ -6273,138 +8122,138 @@ rec { relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:18.1-19.24 rule nop{C : context}: - `%|-%:%`(C, NOP_instr, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + `%|-%:%`(C, NOP_instr, mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) -- wf_context: `%`(C) -- wf_instr: `%`(NOP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:21.1-23.42 rule unreachable{C : context, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, UNREACHABLE_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, UNREACHABLE_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(UNREACHABLE_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:25.1-27.29 rule drop{C : context, t : valtype}: - `%|-%:%`(C, DROP_instr, `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) + `%|-%:%`(C, DROP_instr, mk_instrtype_instrtype(mk_list_resulttype([t]), [], mk_list_resulttype([]))) -- Valtype_ok: `%|-%:OK`(C, t) -- wf_context: `%`(C) -- wf_instr: `%`(DROP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:29.1-31.29 rule select_expl{C : context, t : valtype}: - `%|-%:%`(C, SELECT_instr(?([t])), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + `%|-%:%`(C, SELECT_instr(?([t])), mk_instrtype_instrtype(mk_list_resulttype([t t I32_valtype]), [], mk_list_resulttype([t]))) -- Valtype_ok: `%|-%:OK`(C, t) -- wf_context: `%`(C) -- wf_instr: `%`(SELECT_instr(?([t]))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t t I32_valtype]), [], mk_list_resulttype([t]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:33.1-37.37 rule select_impl{C : context, t : valtype, t' : valtype, v_numtype : numtype, v_vectype : vectype}: - `%|-%:%`(C, SELECT_instr(?()), `%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + `%|-%:%`(C, SELECT_instr(?()), mk_instrtype_instrtype(mk_list_resulttype([t t I32_valtype]), [], mk_list_resulttype([t]))) -- Valtype_ok: `%|-%:OK`(C, t) -- Valtype_sub: `%|-%<:%`(C, t, t') -- if ((t' = $valtype_numtype(v_numtype)) \/ (t' = $valtype_vectype(v_vectype))) -- wf_context: `%`(C) -- wf_valtype: `%`(t') -- wf_instr: `%`(SELECT_instr(?())) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t t I32_valtype]), [], mk_list_resulttype([t]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:53.1-56.67 rule block{C : context, bt : blocktype, instr_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*, x_lst : idx*}: - `%|-%:%`(C, BLOCK_instr(bt, instr_lst), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + `%|-%:%`(C, BLOCK_instr(bt, instr_lst), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Blocktype_ok: `%|-%:%`(C, bt, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(BLOCK_instr(bt, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:58.1-61.67 rule loop{C : context, bt : blocktype, instr_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*, x_lst : idx*}: - `%|-%:%`(C, LOOP_instr(bt, instr_lst), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_1_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + `%|-%:%`(C, LOOP_instr(bt, instr_lst), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Blocktype_ok: `%|-%:%`(C, bt, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_1_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(LOOP_instr(bt, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_1_lst)], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_1_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:63.1-67.71 rule if{C : context, bt : blocktype, instr_1_lst : instr*, instr_2_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*, x_1_lst : idx*, x_2_lst : idx*}: - `%|-%:%`(C, `IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [I32_valtype]), [], `%`_resulttype(t_2_lst))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_1_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_2_lst, `%`_resulttype(t_2_lst))) + `%|-%:%`(C, `IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [I32_valtype]), [], mk_list_resulttype(t_2_lst))) + -- Blocktype_ok: `%|-%:%`(C, bt, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_1_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_2_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_2_lst, mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [I32_valtype]), [], `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_2_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [I32_valtype]), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_2_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:72.1-75.42 rule br{C : context, l : labelidx, t_1_lst : valtype*, t_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, BR_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) + `%|-%:%`(C, BR_instr(l), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t_lst) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:77.1-79.25 rule br_if{C : context, l : labelidx, t_lst : valtype*}: - `%|-%:%`(C, BR_IF_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [I32_valtype]), [], `%`_resulttype(t_lst))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) + `%|-%:%`(C, BR_IF_instr(l), mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [I32_valtype]), [], mk_list_resulttype(t_lst))) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t_lst) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [I32_valtype]), [], `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [I32_valtype]), [], mk_list_resulttype(t_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 rule br_table{C : context, l_lst : labelidx*, l' : labelidx, t_1_lst : valtype*, t_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, BR_TABLE_instr(l_lst, l'), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, BR_TABLE_instr(l_lst, l'), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], mk_list_resulttype(t_2_lst))) + -- (Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]))*{l <- l_lst} -- (if ($proj_uN_0(l).0 < |C.LABELS_context|))*{l <- l_lst} - -- (Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]))*{l <- l_lst} + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l').0]) -- if ($proj_uN_0(l').0 < |C.LABELS_context|) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l').0]) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], `%`_resulttype(t_2_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(BR_TABLE_instr(l_lst, l')) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst ++ [I32_valtype]), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:87.1-90.31 rule br_on_null{C : context, l : labelidx, t_lst : valtype*, ht : heaptype}: - `%|-%:%`(C, BR_ON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t_lst ++ [REF_valtype(?(), ht)]))) - -- if ($proj_uN_0(l).0 < |C.LABELS_context|) + `%|-%:%`(C, BR_ON_NULL_instr(l), mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype(t_lst ++ [REF_valtype(?(), ht)]))) -- if ($proj_list_0(syntax valtype, C.LABELS_context[$proj_uN_0(l).0]).0 = t_lst) + -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NULL_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t_lst ++ [REF_valtype(?(), ht)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype(t_lst ++ [REF_valtype(?(), ht)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:92.1-94.40 rule br_on_non_null{C : context, l : labelidx, t_lst : valtype*, ht : heaptype}: - `%|-%:%`(C, BR_ON_NON_NULL_instr(l), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t_lst))) + `%|-%:%`(C, BR_ON_NON_NULL_instr(l), mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype(t_lst))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = mk_list_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)])) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)])) -- wf_context: `%`(C) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype(t_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, t_lst : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) + `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], mk_list_resulttype(t_lst ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = mk_list_resulttype(t_lst ++ [$valtype_reftype(rt)])) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t_lst ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) @@ -6412,974 +8261,984 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], mk_list_resulttype(t_lst ++ [$valtype_reftype($diffrt(rt_1, rt_2))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:104.1-110.49 rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, t_lst : valtype*, rt : reftype}: - `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype(rt_2)]))) + `%|-%:%`(C, BR_ON_CAST_FAIL_instr(l, rt_1, rt_2), mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_2)]))) + -- if (C.LABELS_context[$proj_uN_0(l).0] = mk_list_resulttype(t_lst ++ [$valtype_reftype(rt)])) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) - -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t_lst ++ [$valtype_reftype(rt)])) -- Reftype_ok: `%|-%:OK`(C, rt_1) -- Reftype_ok: `%|-%:OK`(C, rt_2) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) + -- wf_reftype: `%`($diffrt(rt_1, rt_2)) -- wf_instr: `%`(BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype(rt_2)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], mk_list_resulttype(t_lst ++ [$valtype_reftype(rt_2)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:115.1-117.45 rule call{C : context, x : idx, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, CALL_instr(x), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) - -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 rule call_ref{C : context, x : idx, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, CALL_REF_instr(_IDX_typeuse(x)), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype(t_2_lst))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_REF_instr(_IDX_typeuse(x))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_2_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 rule call_indirect{C : context, x : idx, y : idx, t_1_lst : valtype*, at : addrtype, t_2_lst : valtype*, lim : limits, rt : reftype}: - `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, CALL_INDIRECT_instr(x, _IDX_typeuse(y)), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [$valtype_addrtype(at)]), [], mk_list_resulttype(t_2_lst))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(y).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_2_lst))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [$valtype_addrtype(at)]), [], mk_list_resulttype(t_2_lst))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:129.1-132.42 rule return{C : context, t_1_lst : valtype*, t_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, RETURN_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) - -- if (C.RETURN_context = ?(`%`_resulttype(t_lst))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, RETURN_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) + -- if (C.RETURN_context = ?(mk_list_resulttype(t_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(RETURN_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:135.1-140.42 rule return_call{C : context, x : idx, t_3_lst : valtype*, t_1_lst : valtype*, t_4_lst : valtype*, t_2_lst : valtype*, t'_2_lst : valtype*}: - `%|-%:%`(C, RETURN_CALL_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst), [], `%`_resulttype(t_4_lst))) + `%|-%:%`(C, RETURN_CALL_instr(x), mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst), [], mk_list_resulttype(t_4_lst))) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) - -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2_lst))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2_lst), `%`_resulttype(t'_2_lst)) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- if (C.RETURN_context = ?(mk_list_resulttype(t'_2_lst))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_2_lst), mk_list_resulttype(t'_2_lst)) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) -- wf_context: `%`(C) -- (wf_valtype: `%`(t'_2))*{t'_2 <- t'_2_lst} -- wf_instr: `%`(RETURN_CALL_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst), [], `%`_resulttype(t_4_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst), [], mk_list_resulttype(t_4_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:143.1-148.42 rule return_call_ref{C : context, x : idx, t_3_lst : valtype*, t_1_lst : valtype*, t_4_lst : valtype*, t_2_lst : valtype*, t'_2_lst : valtype*}: - `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), `%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4_lst))) + `%|-%:%`(C, RETURN_CALL_REF_instr(_IDX_typeuse(x)), mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype(t_4_lst))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2_lst))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2_lst), `%`_resulttype(t'_2_lst)) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- if (C.RETURN_context = ?(mk_list_resulttype(t'_2_lst))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_2_lst), mk_list_resulttype(t'_2_lst)) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) -- wf_context: `%`(C) -- (wf_valtype: `%`(t'_2))*{t'_2 <- t'_2_lst} -- wf_instr: `%`(RETURN_CALL_REF_instr(_IDX_typeuse(x))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype(t_4_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst ++ [REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype(t_4_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:151.1-159.42 rule return_call_indirect{C : context, x : idx, y : idx, t_3_lst : valtype*, t_1_lst : valtype*, at : addrtype, t_4_lst : valtype*, lim : limits, rt : reftype, t_2_lst : valtype*, t'_2_lst : valtype*}: - `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), `%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4_lst))) + `%|-%:%`(C, RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)), mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst ++ [$valtype_addrtype(at)]), [], mk_list_resulttype(t_4_lst))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- Reftype_sub: `%|-%<:%`(C, rt, REF_reftype(?(NULL_null), FUNC_heaptype)) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(y).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(y).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- if (C.RETURN_context = ?(`%`_resulttype(t'_2_lst))) - -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_2_lst), `%`_resulttype(t'_2_lst)) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- if (C.RETURN_context = ?(mk_list_resulttype(t'_2_lst))) + -- Resulttype_sub: `%|-%<:%`(C, mk_list_resulttype(t_2_lst), mk_list_resulttype(t'_2_lst)) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) -- wf_context: `%`(C) -- (wf_valtype: `%`(t'_2))*{t'_2 <- t'_2_lst} -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst ++ t_1_lst ++ [$valtype_addrtype(at)]), [], `%`_resulttype(t_4_lst))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst ++ t_1_lst ++ [$valtype_addrtype(at)]), [], mk_list_resulttype(t_4_lst))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_resulttype(t_4_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_3_lst), [], mk_list_resulttype(t_4_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:166.1-169.42 rule throw{C : context, x : idx, t_1_lst : valtype*, t_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, THROW_instr(x), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) + -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- Expand: `%~~%`(!($as_deftype(C.TAGS_context[$proj_uN_0(x).0])), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(THROW_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_resulttype(t_2_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ t_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, THROW_REF_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], `%`_resulttype(t_2_lst))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, THROW_REF_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], mk_list_resulttype(t_2_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(THROW_REF_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst ++ [REF_valtype(?(NULL_null), EXN_heaptype)]), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:175.1-179.34 rule try_table{C : context, bt : blocktype, catch_lst : catch*, instr_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*, x_lst : idx*}: - `%|-%:%`(C, TRY_TABLE_instr(bt, `%`_list(catch_lst), instr_lst), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Blocktype_ok: `%|-%:%`(C, bt, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + `%|-%:%`(C, TRY_TABLE_instr(bt, mk_list_list(catch_lst), instr_lst), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Blocktype_ok: `%|-%:%`(C, bt, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrs_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) -- (Catch_ok: `%|-%:OK`(C, v_catch))*{v_catch <- catch_lst} -- wf_context: `%`(C) - -- wf_instr: `%`(TRY_TABLE_instr(bt, `%`_list(catch_lst), instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instr: `%`(TRY_TABLE_instr(bt, mk_list_list(catch_lst), instr_lst)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:202.1-204.31 rule ref_null{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.NULL`_instr(ht), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(NULL_null), ht)]))) + `%|-%:%`(C, REF_NULL_instr(ht), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(NULL_null), ht)]))) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.NULL`_instr(ht)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(NULL_null), ht)]))) + -- wf_instr: `%`(REF_NULL_instr(ht)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(NULL_null), ht)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:206.1-209.20 rule ref_func{C : context, x : idx, dt : deftype}: - `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) + `%|-%:%`(C, REF_FUNC_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) - -- if (|C.REFS_context| > 0) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (x <- C.REFS_context) + -- if (|C.REFS_context| > 0) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.FUNC`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) + -- wf_instr: `%`(REF_FUNC_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 rule ref_i31{C : context}: - `%|-%:%`(C, `REF.I31`_instr, `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), I31_heaptype)]))) + `%|-%:%`(C, REF_I31_instr, mk_instrtype_instrtype(mk_list_resulttype([I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), I31_heaptype)]))) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.I31`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), I31_heaptype)]))) + -- wf_instr: `%`(REF_I31_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), I31_heaptype)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:214.1-216.31 rule ref_is_null{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.IS_NULL`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, REF_IS_NULL_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype([I32_valtype]))) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instr: `%`(REF_IS_NULL_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:218.1-220.31 rule ref_as_non_null{C : context, ht : heaptype}: - `%|-%:%`(C, `REF.AS_NON_NULL`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([REF_valtype(?(), ht)]))) + `%|-%:%`(C, REF_AS_NON_NULL_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype([REF_valtype(?(), ht)]))) -- Heaptype_ok: `%|-%:OK`(C, ht) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([REF_valtype(?(), ht)]))) + -- wf_instr: `%`(REF_AS_NON_NULL_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ht)]), [], mk_list_resulttype([REF_valtype(?(), ht)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:222.1-223.51 rule ref_eq{C : context}: - `%|-%:%`(C, `REF.EQ`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, REF_EQ_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instr: `%`(REF_EQ_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), EQ_heaptype) REF_valtype(?(NULL_null), EQ_heaptype)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:225.1-229.33 rule ref_test{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.TEST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, REF_TEST_instr(rt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt')]), [], mk_list_resulttype([I32_valtype]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.TEST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) + -- wf_instr: `%`(REF_TEST_instr(rt)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt')]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:231.1-235.33 rule ref_cast{C : context, rt : reftype, rt' : reftype}: - `%|-%:%`(C, `REF.CAST`_instr(rt), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) + `%|-%:%`(C, REF_CAST_instr(rt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt')]), [], mk_list_resulttype([$valtype_reftype(rt)]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.CAST`_instr(rt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- wf_instr: `%`(REF_CAST_instr(rt)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt')]), [], mk_list_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:240.1-241.42 rule i31_get{C : context, v_sx : sx}: - `%|-%:%`(C, `I31.GET`_instr(v_sx), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, I31_GET_instr(v_sx), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) - -- wf_instr: `%`(`I31.GET`_instr(v_sx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instr: `%`(I31_GET_instr(v_sx)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), I31_heaptype)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:246.1-248.45 rule struct_new{C : context, x : idx, zt_lst : storagetype*, mut_opt_lst : mut?*}: - `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- zt_lst}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, STRUCT_NEW_instr(x), mk_instrtype_instrtype(mk_list_resulttype($unpack(zt)*{zt <- zt_lst}), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- zt_lst}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_instr: `%`(STRUCT_NEW_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype($unpack(zt)*{zt <- zt_lst}), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 rule struct_new_default{C : context, x : idx, mut_opt_lst : mut?*, zt_lst : storagetype*}: - `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, STRUCT_NEW_DEFAULT_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- (Defaultable: `|-%DEFAULTABLE`($unpack(zt)))*{zt <- zt_lst} -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (wf_valtype: `%`($unpack(zt)))*{zt <- zt_lst} + -- wf_instr: `%`(STRUCT_NEW_DEFAULT_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:258.1-262.41 rule struct_get{C : context, sx_opt : sx?, x : idx, i : fieldidx, zt : storagetype, ft_lst : fieldtype*, mut_opt : mut?}: - `%|-%:%`(C, `STRUCT.GET`_instr(sx_opt, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) + `%|-%:%`(C, STRUCT_GET_instr(sx_opt, x, i), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype([$unpack(zt)]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(mk_list_list(ft_lst))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft_lst))) + -- if (ft_lst[$proj_uN_0(i).0] = mk_fieldtype_fieldtype(mut_opt, zt)) -- if ($proj_uN_0(i).0 < |ft_lst|) - -- if (ft_lst[$proj_uN_0(i).0] = `%%`_fieldtype(mut_opt, zt)) -- if ((sx_opt =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.GET`_instr(sx_opt, x, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([$unpack(zt)]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_lst))) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, zt)) + -- wf_instr: `%`(STRUCT_GET_instr(sx_opt, x, i)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], mk_list_resulttype([$unpack(zt)]))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(ft_lst))) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(mut_opt, zt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:264.1-267.24 rule struct_set{C : context, x : idx, i : fieldidx, zt : storagetype, ft_lst : fieldtype*}: - `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) + `%|-%:%`(C, STRUCT_SET_instr(x, i), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(mk_list_list(ft_lst))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft_lst))) + -- if (ft_lst[$proj_uN_0(i).0] = mk_fieldtype_fieldtype(?(MUT_mut), zt)) -- if ($proj_uN_0(i).0 < |ft_lst|) - -- if (ft_lst[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_lst))) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt)) + -- wf_instr: `%`(STRUCT_SET_instr(x, i)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) $unpack(zt)]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(ft_lst))) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(MUT_mut), zt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 rule array_new{C : context, x : idx, zt : storagetype, mut_opt : mut?}: - `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, ARRAY_NEW_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$unpack(zt) I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_instr: `%`(ARRAY_NEW_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$unpack(zt) I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 rule array_new_default{C : context, x : idx, mut_opt : mut?, zt : storagetype}: - `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, ARRAY_NEW_DEFAULT_instr(x), mk_instrtype_instrtype(mk_list_resulttype([I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_valtype: `%`($unpack(zt)) + -- wf_instr: `%`(ARRAY_NEW_DEFAULT_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:281.1-283.43 rule array_new_fixed{C : context, x : idx, v_n : n, zt : storagetype, mut_opt : mut?}: - `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n)), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)^v_n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n)), mk_instrtype_instrtype(mk_list_resulttype($unpack(zt)^v_n{}), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)^v_n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype($unpack(zt)^v_n{}), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 rule array_new_elem{C : context, x : idx, y : idx, mut_opt : mut?, rt : reftype}: - `%|-%:%`(C, `ARRAY.NEW_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, ARRAY_NEW_ELEM_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, $storagetype_reftype(rt)))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, $storagetype_reftype(rt)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_ELEM`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, $storagetype_reftype(rt)))) + -- wf_instr: `%`(ARRAY_NEW_ELEM_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, $storagetype_reftype(rt)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 rule array_new_data{C : context, x : idx, y : idx, mut_opt : mut?, zt : storagetype, v_numtype : numtype, v_vectype : vectype}: - `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + `%|-%:%`(C, ARRAY_NEW_DATA_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if (($unpack(zt) = $valtype_numtype(v_numtype)) \/ ($unpack(zt) = $valtype_vectype(v_vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_valtype: `%`($unpack(zt)) + -- wf_instr: `%`(ARRAY_NEW_DATA_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 rule array_get{C : context, sx_opt : sx?, x : idx, zt : storagetype, mut_opt : mut?}: - `%|-%:%`(C, `ARRAY.GET`_instr(sx_opt, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) + `%|-%:%`(C, ARRAY_GET_instr(sx_opt, x), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], mk_list_resulttype([$unpack(zt)]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if ((sx_opt =/= ?()) <=> $is_packtype(zt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx_opt, x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([$unpack(zt)]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_instr: `%`(ARRAY_GET_instr(sx_opt, x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], mk_list_resulttype([$unpack(zt)]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 rule array_set{C : context, x : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) + `%|-%:%`(C, ARRAY_SET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- wf_instr: `%`(ARRAY_SET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt)]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 rule array_len{C : context}: - `%|-%:%`(C, `ARRAY.LEN`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, ARRAY_LEN_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.LEN`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instr: `%`(ARRAY_LEN_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), ARRAY_heaptype)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:308.1-310.42 rule array_fill{C : context, x : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) + `%|-%:%`(C, ARRAY_FILL_instr(x), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- wf_instr: `%`(ARRAY_FILL_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype $unpack(zt) I32_valtype]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 rule array_copy{C : context, x_1 : idx, x_2 : idx, zt_1 : storagetype, mut_opt : mut?, zt_2 : storagetype}: - `%|-%:%`(C, `ARRAY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + `%|-%:%`(C, ARRAY_COPY_instr(x_1, x_2), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt_1))) -- if ($proj_uN_0(x_1).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_1).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) -- if ($proj_uN_0(x_2).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x_2).0], ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt_1))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) + -- wf_instr: `%`(ARRAY_COPY_instr(x_1, x_2)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x_1)) I32_valtype REF_valtype(?(NULL_null), _IDX_heaptype(x_2)) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt_1))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:318.1-321.44 rule array_init_elem{C : context, x : idx, y : idx, zt : storagetype}: - `%|-%:%`(C, `ARRAY.INIT_ELEM`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) + `%|-%:%`(C, ARRAY_INIT_ELEM_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), zt) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- wf_instr: `%`(ARRAY_INIT_ELEM_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 rule array_init_data{C : context, x : idx, y : idx, zt : storagetype, v_numtype : numtype, v_vectype : vectype}: - `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) + `%|-%:%`(C, ARRAY_INIT_DATA_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) -- if (($unpack(zt) = $valtype_numtype(v_numtype)) \/ ($unpack(zt) = $valtype_vectype(v_vectype))) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) + -- wf_valtype: `%`($unpack(zt)) + -- wf_instr: `%`(ARRAY_INIT_DATA_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:332.1-334.26 rule extern_convert_any{C : context, null_1_opt : null?, null_2_opt : null?}: - `%|-%:%`(C, `EXTERN.CONVERT_ANY`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1_opt, ANY_heaptype)]), [], `%`_resulttype([REF_valtype(null_2_opt, EXTERN_heaptype)]))) + `%|-%:%`(C, EXTERN_CONVERT_ANY_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(null_1_opt, ANY_heaptype)]), [], mk_list_resulttype([REF_valtype(null_2_opt, EXTERN_heaptype)]))) -- if (null_1_opt = null_2_opt) -- wf_context: `%`(C) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1_opt, ANY_heaptype)]), [], `%`_resulttype([REF_valtype(null_2_opt, EXTERN_heaptype)]))) + -- wf_instr: `%`(EXTERN_CONVERT_ANY_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(null_1_opt, ANY_heaptype)]), [], mk_list_resulttype([REF_valtype(null_2_opt, EXTERN_heaptype)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:336.1-338.26 rule any_convert_extern{C : context, null_1_opt : null?, null_2_opt : null?}: - `%|-%:%`(C, `ANY.CONVERT_EXTERN`_instr, `%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1_opt, EXTERN_heaptype)]), [], `%`_resulttype([REF_valtype(null_2_opt, ANY_heaptype)]))) + `%|-%:%`(C, ANY_CONVERT_EXTERN_instr, mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(null_1_opt, EXTERN_heaptype)]), [], mk_list_resulttype([REF_valtype(null_2_opt, ANY_heaptype)]))) -- if (null_1_opt = null_2_opt) -- wf_context: `%`(C) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(null_1_opt, EXTERN_heaptype)]), [], `%`_resulttype([REF_valtype(null_2_opt, ANY_heaptype)]))) + -- wf_instr: `%`(ANY_CONVERT_EXTERN_instr) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([REF_valtype(null_1_opt, EXTERN_heaptype)]), [], mk_list_resulttype([REF_valtype(null_2_opt, ANY_heaptype)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:343.1-345.28 rule local_get{C : context, x : idx, t : valtype}: - `%|-%:%`(C, `LOCAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + `%|-%:%`(C, LOCAL_GET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = mk_localtype_localtype(SET_init, t)) -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) - -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(SET_init, t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) + -- wf_instr: `%`(LOCAL_GET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- wf_localtype: `%`(mk_localtype_localtype(SET_init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 rule local_set{C : context, x : idx, t : valtype, v_init : init}: - `%|-%:%`(C, `LOCAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) + `%|-%:%`(C, LOCAL_SET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([t]), [x], mk_list_resulttype([]))) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = mk_localtype_localtype(v_init, t)) -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) - -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(v_init, t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) - -- wf_localtype: `%`(`%%`_localtype(v_init, t)) + -- wf_instr: `%`(LOCAL_SET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t]), [x], mk_list_resulttype([]))) + -- wf_localtype: `%`(mk_localtype_localtype(v_init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 rule local_tee{C : context, x : idx, t : valtype, v_init : init}: - `%|-%:%`(C, `LOCAL.TEE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) + `%|-%:%`(C, LOCAL_TEE_instr(x), mk_instrtype_instrtype(mk_list_resulttype([t]), [x], mk_list_resulttype([t]))) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = mk_localtype_localtype(v_init, t)) -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) - -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(v_init, t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) - -- wf_localtype: `%`(`%%`_localtype(v_init, t)) + -- wf_instr: `%`(LOCAL_TEE_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t]), [x], mk_list_resulttype([t]))) + -- wf_localtype: `%`(mk_localtype_localtype(v_init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 rule global_get{C : context, x : idx, t : valtype, mut_opt : mut?}: - `%|-%:%`(C, `GLOBAL.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + `%|-%:%`(C, GLOBAL_GET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = mk_globaltype_globaltype(mut_opt, t)) -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) - -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut_opt, t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, t)) + -- wf_instr: `%`(GLOBAL_GET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- wf_globaltype: `%`(mk_globaltype_globaltype(mut_opt, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 rule global_set{C : context, x : idx, t : valtype}: - `%|-%:%`(C, `GLOBAL.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) + `%|-%:%`(C, GLOBAL_SET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([t]), [], mk_list_resulttype([]))) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = mk_globaltype_globaltype(?(MUT_mut), t)) -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) - -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(MUT_mut), t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) + -- wf_instr: `%`(GLOBAL_SET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([t]), [], mk_list_resulttype([]))) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(MUT_mut), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 rule table_get{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) + `%|-%:%`(C, TABLE_GET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_reftype(rt)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instr: `%`(TABLE_GET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_reftype(rt)]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 rule table_set{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) + `%|-%:%`(C, TABLE_SET_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], mk_list_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instr: `%`(TABLE_SET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], mk_list_resulttype([]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 rule table_size{C : context, x : idx, at : addrtype, lim : limits, rt : reftype}: - `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + `%|-%:%`(C, TABLE_SIZE_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_addrtype(at)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instr: `%`(TABLE_SIZE_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_addrtype(at)]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 rule table_grow{C : context, x : idx, rt : reftype, at : addrtype, lim : limits}: - `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) + `%|-%:%`(C, TABLE_GROW_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(at)]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instr: `%`(TABLE_GROW_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(at)]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 rule table_fill{C : context, x : idx, at : addrtype, rt : reftype, lim : limits}: - `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) + `%|-%:%`(C, TABLE_FILL_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], mk_list_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_instr: `%`(TABLE_FILL_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], mk_list_resulttype([]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 rule table_copy{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, rt_1 : reftype, lim_2 : limits, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) + `%|-%:%`(C, TABLE_COPY_instr(x_1, x_2), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], mk_list_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x_1).0] = mk_tabletype_tabletype(at_1, lim_1, rt_1)) -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x_1).0] = `%%%`_tabletype(at_1, lim_1, rt_1)) + -- if (C.TABLES_context[$proj_uN_0(x_2).0] = mk_tabletype_tabletype(at_2, lim_2, rt_2)) -- if ($proj_uN_0(x_2).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x_2).0] = `%%%`_tabletype(at_2, lim_2, rt_2)) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) - -- wf_instr: `%`(`TABLE.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at_1, lim_1, rt_1)) - -- wf_tabletype: `%`(`%%%`_tabletype(at_2, lim_2, rt_2)) + -- wf_instr: `%`(TABLE_COPY_instr(x_1, x_2)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], mk_list_resulttype([]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at_1, lim_1, rt_1)) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at_2, lim_2, rt_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:395.1-399.36 rule table_init{C : context, x : idx, y : idx, at : addrtype, lim : limits, rt_1 : reftype, rt_2 : reftype}: - `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + `%|-%:%`(C, TABLE_INIT_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt_1)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(y).0] = rt_2) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- wf_context: `%`(C) -- wf_reftype: `%`(rt_2) - -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt_1)) + -- wf_instr: `%`(TABLE_INIT_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt_1)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:401.1-403.24 rule elem_drop{C : context, x : idx, rt : reftype}: - `%|-%:%`(C, `ELEM.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) + `%|-%:%`(C, ELEM_DROP_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) + -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- wf_instr: `%`(ELEM_DROP_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 rule memory_size{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, MEMORY_SIZE_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_addrtype(at)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- wf_instr: `%`(MEMORY_SIZE_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 rule memory_grow{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, MEMORY_GROW_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(at)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- wf_instr: `%`(MEMORY_GROW_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 rule memory_fill{C : context, x : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, MEMORY_FILL_instr(x), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) + -- wf_instr: `%`(MEMORY_FILL_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 rule memory_copy{C : context, x_1 : idx, x_2 : idx, at_1 : addrtype, at_2 : addrtype, lim_1 : limits, lim_2 : limits}: - `%|-%:%`(C, `MEMORY.COPY`_instr(x_1, x_2), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) + `%|-%:%`(C, MEMORY_COPY_instr(x_1, x_2), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x_1).0] = `%%PAGE`_memtype(at_1, lim_1)) - -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) + -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x_2).0] = `%%PAGE`_memtype(at_2, lim_2)) + -- if ($proj_uN_0(x_2).0 < |C.MEMS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], `%`_resulttype([]))) + -- wf_instr: `%`(MEMORY_COPY_instr(x_1, x_2)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at_1) $valtype_addrtype(at_2) $valtype_addrtype($minat(at_1, at_2))]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at_1, lim_1)) -- wf_memtype: `%`(`%%PAGE`_memtype(at_2, lim_2)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 rule memory_init{C : context, x : idx, y : idx, at : addrtype, lim : limits}: - `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, MEMORY_INIT_instr(x, y), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_instr: `%`(MEMORY_INIT_instr(x, y)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 rule data_drop{C : context, x : idx}: - `%|-%:%`(C, `DATA.DROP`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) + `%|-%:%`(C, DATA_DROP_instr(x), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) + -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- wf_context: `%`(C) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- wf_instr: `%`(DATA_DROP_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 rule load_val{C : context, nt : numtype, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr(nt, ?(), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, LOAD_instr(nt, ?(), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:456.1-459.36 rule load_pack{C : context, v_Inn : Inn, v_M : M, v_sx : sx, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_M), v_sx))), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(v_Inn)]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_M), v_sx))), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(v_Inn)]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_M) -- wf_context: `%`(C) - -- wf_instr: `%`(LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_M), v_sx))), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(v_Inn)]))) + -- wf_instr: `%`(LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_M), v_sx))), x, v_memarg)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([$valtype_addrtype(v_Inn)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:470.1-473.44 rule store_val{C : context, nt : numtype, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr(nt, ?(), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, STORE_instr(nt, ?(), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, $size(nt)) -- wf_context: `%`(C) -- wf_instr: `%`(STORE_instr(nt, ?(), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:475.1-478.36 rule store_pack{C : context, v_Inn : Inn, v_M : M, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_M)))), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(v_Inn)]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_M)))), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_addrtype(v_Inn)]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_M) -- wf_context: `%`(C) - -- wf_instr: `%`(STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_M)))), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_addrtype(v_Inn)]), [], `%`_resulttype([]))) + -- wf_instr: `%`(STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_M)))), x, v_memarg)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) $valtype_addrtype(v_Inn)]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:480.1-483.47 rule vload_val{C : context, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:485.1-488.41 rule vload_pack{C : context, v_M : M, v_N : N, v_sx : sx, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(v_M), v_N, v_sx)), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(v_M), v_N, v_sx)), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, (v_M * v_N)) -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(v_M), v_N, v_sx)), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(v_M), v_N, v_sx)), x, v_memarg)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:490.1-493.36 rule vload_splat{C : context, v_N : N, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_N) -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, v_memarg)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:495.1-498.36 rule vload_zero{C : context, v_N : N, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_N) -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, v_memarg)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at)]), [], mk_list_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:500.1-504.21 rule vload_lane{C : context, v_N : N, x : idx, v_memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, v_memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, v_memarg, i), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (v_N : nat <:> rat))) -- wf_context: `%`(C) - -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, v_memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, v_memarg, i)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:506.1-509.47 rule vstore{C : context, x : idx, v_memarg : memarg, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_instr(V128_vectype, x, v_memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VSTORE_instr(V128_vectype, x, v_memarg), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, $vsize(V128_vectype)) -- wf_context: `%`(C) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, v_memarg)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:511.1-515.21 rule vstore_lane{C : context, v_N : N, x : idx, v_memarg : memarg, i : laneidx, at : addrtype, lim : limits}: - `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, v_memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, v_memarg, i), mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([]))) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Memarg_ok: `|-%:%->%`(v_memarg, at, v_N) -- if (($proj_uN_0(i).0 : nat <:> rat) < ((128 : nat <:> rat) / (v_N : nat <:> rat))) -- wf_context: `%`(C) - -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, v_memarg, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, v_memarg, i)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_addrtype(at) V128_valtype]), [], mk_list_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:520.1-521.33 rule const{C : context, nt : numtype, c_nt : num_}: - `%|-%:%`(C, CONST_instr(nt, c_nt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) + `%|-%:%`(C, CONST_instr(nt, c_nt), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CONST_instr(nt, c_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:523.1-524.34 rule unop{C : context, nt : numtype, unop_nt : unop_}: - `%|-%:%`(C, UNOP_instr(nt, unop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + `%|-%:%`(C, UNOP_instr(nt, unop_nt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(UNOP_instr(nt, unop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:526.1-527.39 rule binop{C : context, nt : numtype, binop_nt : binop_}: - `%|-%:%`(C, BINOP_instr(nt, binop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + `%|-%:%`(C, BINOP_instr(nt, binop_nt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr(nt, binop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], mk_list_resulttype([$valtype_numtype(nt)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:529.1-530.39 rule testop{C : context, nt : numtype, testop_nt : testop_}: - `%|-%:%`(C, TESTOP_instr(nt, testop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, TESTOP_instr(nt, testop_nt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt)]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(TESTOP_instr(nt, testop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:532.1-533.40 rule relop{C : context, nt : numtype, relop_nt : relop_}: - `%|-%:%`(C, RELOP_instr(nt, relop_nt), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, RELOP_instr(nt, relop_nt), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(RELOP_instr(nt, relop_nt)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt) $valtype_numtype(nt)]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:535.1-536.44 rule cvtop{C : context, nt_1 : numtype, nt_2 : numtype, cvtop : cvtop__}: - `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) + `%|-%:%`(C, CVTOP_instr(nt_1, nt_2, cvtop), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt_2)]), [], mk_list_resulttype([$valtype_numtype(nt_1)]))) -- wf_context: `%`(C) -- wf_instr: `%`(CVTOP_instr(nt_1, nt_2, cvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype(nt_2)]), [], `%`_resulttype([$valtype_numtype(nt_1)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype(nt_2)]), [], mk_list_resulttype([$valtype_numtype(nt_1)]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:541.1-542.35 rule vconst{C : context, c : vec_}: - `%|-%:%`(C, VCONST_instr(V128_vectype, c), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VCONST_instr(V128_vectype, c), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:544.1-545.41 rule vvunop{C : context, v_vvunop : vvunop}: - `%|-%:%`(C, VVUNOP_instr(V128_vectype, v_vvunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VVUNOP_instr(V128_vectype, v_vvunop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, v_vvunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:547.1-548.48 rule vvbinop{C : context, v_vvbinop : vvbinop}: - `%|-%:%`(C, VVBINOP_instr(V128_vectype, v_vvbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VVBINOP_instr(V128_vectype, v_vvbinop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, v_vvbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:550.1-551.55 rule vvternop{C : context, v_vvternop : vvternop}: - `%|-%:%`(C, VVTERNOP_instr(V128_vectype, v_vvternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VVTERNOP_instr(V128_vectype, v_vvternop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, v_vvternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:553.1-554.44 rule vvtestop{C : context, v_vvtestop : vvtestop}: - `%|-%:%`(C, VVTESTOP_instr(V128_vectype, v_vvtestop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, VVTESTOP_instr(V128_vectype, v_vvtestop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, v_vvtestop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:556.1-557.37 rule vunop{C : context, sh : shape, vunop : vunop_}: - `%|-%:%`(C, VUNOP_instr(sh, vunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VUNOP_instr(sh, vunop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:559.1-560.44 rule vbinop{C : context, sh : shape, vbinop : vbinop_}: - `%|-%:%`(C, VBINOP_instr(sh, vbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VBINOP_instr(sh, vbinop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:562.1-563.51 rule vternop{C : context, sh : shape, vternop : vternop_}: - `%|-%:%`(C, VTERNOP_instr(sh, vternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VTERNOP_instr(sh, vternop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:565.1-566.40 rule vtestop{C : context, sh : shape, vtestop : vtestop_}: - `%|-%:%`(C, VTESTOP_instr(sh, vtestop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, VTESTOP_instr(sh, vtestop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VTESTOP_instr(sh, vtestop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:568.1-569.44 rule vrelop{C : context, sh : shape, vrelop : vrelop_}: - `%|-%:%`(C, VRELOP_instr(sh, vrelop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VRELOP_instr(sh, vrelop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:571.1-572.47 rule vshiftop{C : context, sh : ishape, vshiftop : vshiftop_}: - `%|-%:%`(C, VSHIFTOP_instr(sh, vshiftop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype I32_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSHIFTOP_instr(sh, vshiftop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype I32_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype I32_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype I32_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:574.1-575.33 rule vbitmask{C : context, sh : ishape}: - `%|-%:%`(C, VBITMASK_instr(sh), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, VBITMASK_instr(sh), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VBITMASK_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:577.1-578.50 rule vswizzlop{C : context, sh : bshape, vswizzlop : vswizzlop_}: - `%|-%:%`(C, VSWIZZLOP_instr(sh, vswizzlop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSWIZZLOP_instr(sh, vswizzlop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSWIZZLOP_instr(sh, vswizzlop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:580.1-582.29 rule vshuffle{C : context, sh : bshape, i_lst : laneidx*}: - `%|-%:%`(C, VSHUFFLE_instr(sh, i_lst), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSHUFFLE_instr(sh, i_lst), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($fun_dim($proj_bshape_0(sh).0)).0)))*{i <- i_lst} -- wf_context: `%`(C) + -- wf_dim: `%`($fun_dim($proj_bshape_0(sh).0)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 rule vsplat{C : context, sh : shape}: - `%|-%:%`(C, VSPLAT_instr(sh), `%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VSPLAT_instr(sh), mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype($unpackshape(sh))]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSPLAT_instr(sh)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([$valtype_numtype($unpackshape(sh))]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:587.1-589.21 rule vextract_lane{C : context, sh : shape, sx_opt : sx?, i : laneidx}: - `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx_opt, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx_opt, i), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([$valtype_numtype($unpackshape(sh))]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($fun_dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($fun_dim(sh)) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx_opt, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([$valtype_numtype($unpackshape(sh))]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 rule vreplace_lane{C : context, sh : shape, i : laneidx}: - `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], mk_list_resulttype([V128_valtype]))) -- if ($proj_uN_0(i).0 < $proj_dim_0($fun_dim(sh)).0) -- wf_context: `%`(C) + -- wf_dim: `%`($fun_dim(sh)) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:595.1-596.50 rule vextunop{C : context, sh_1 : ishape, sh_2 : ishape, vextunop : vextunop__}: - `%|-%:%`(C, VEXTUNOP_instr(sh_1, sh_2, vextunop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VEXTUNOP_instr(sh_1, sh_2, vextunop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTUNOP_instr(sh_1, sh_2, vextunop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:598.1-599.57 rule vextbinop{C : context, sh_1 : ishape, sh_2 : ishape, vextbinop : vextbinop__}: - `%|-%:%`(C, VEXTBINOP_instr(sh_1, sh_2, vextbinop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VEXTBINOP_instr(sh_1, sh_2, vextbinop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTBINOP_instr(sh_1, sh_2, vextbinop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:601.1-602.64 rule vextternop{C : context, sh_1 : ishape, sh_2 : ishape, vextternop : vextternop__}: - `%|-%:%`(C, VEXTTERNOP_instr(sh_1, sh_2, vextternop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VEXTTERNOP_instr(sh_1, sh_2, vextternop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTTERNOP_instr(sh_1, sh_2, vextternop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:604.1-605.48 rule vnarrow{C : context, sh_1 : ishape, sh_2 : ishape, v_sx : sx}: - `%|-%:%`(C, VNARROW_instr(sh_1, sh_2, v_sx), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VNARROW_instr(sh_1, sh_2, v_sx), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VNARROW_instr(sh_1, sh_2, v_sx)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:607.1-608.46 rule vcvtop{C : context, sh_1 : shape, sh_2 : shape, vcvtop : vcvtop__}: - `%|-%:%`(C, VCVTOP_instr(sh_1, sh_2, vcvtop), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + `%|-%:%`(C, VCVTOP_instr(sh_1, sh_2, vcvtop), mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VCVTOP_instr(sh_1, sh_2, vcvtop)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([V128_valtype]), [], mk_list_resulttype([V128_valtype]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:6.1-6.96 relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:613.1-614.24 rule empty{C : context}: - `%|-%:%`(C, [], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + `%|-%:%`(C, [], mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) -- wf_context: `%`(C) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:617.1-621.82 - rule seq{C : context, instr_1 : instr, instr_2_lst : instr*, t_1_lst : valtype*, x_1_lst : idx*, x_2_lst : idx*, t_3_lst : valtype*, t_2_lst : valtype*, init_lst : init*, t_lst : valtype*}: - `%|-%:%`(C, [instr_1] ++ instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) - -- Instr_ok: `%|-%:%`(C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) + rule seq{C : context, instr_1 : instr, instr_2_lst : instr*, t_1_lst : valtype*, x_1_lst : idx*, x_2_lst : idx*, t_3_lst : valtype*, t_2_lst : valtype*, init_lst : init*, t_lst : valtype*, var_0 : context?}: + `%|-%:%`(C, [instr_1] ++ instr_2_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst ++ x_2_lst, mk_list_resulttype(t_3_lst))) + -- Instr_ok: `%|-%:%`(C, instr_1, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = mk_localtype_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst, x_1 <- x_1_lst} -- if (|init_lst| = |t_lst|) -- if (|init_lst| = |x_1_lst|) -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- x_1_lst} - -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst, x_1 <- x_1_lst} - -- if ($with_locals(C, x_1_lst, `%%`_localtype(SET_init, t)*{t <- t_lst}) =/= ?()) - -- Instrs_ok: `%|-%:%`(!($with_locals(C, x_1_lst, `%%`_localtype(SET_init, t)*{t <- t_lst})), instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- Instrs_ok: `%|-%:%`(!(var_0), instr_2_lst, mk_instrtype_instrtype(mk_list_resulttype(t_2_lst), x_2_lst, mk_list_resulttype(t_3_lst))) + -- if (var_0 =/= ?()) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- instr_2_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) - -- (wf_localtype: `%`(`%%`_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst} - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- t_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- wf_context: `%`(!(var_0)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst ++ x_2_lst, mk_list_resulttype(t_3_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- (wf_localtype: `%`(mk_localtype_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst} + -- (wf_localtype: `%`(mk_localtype_localtype(SET_init, t)))*{t <- t_lst} + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_2_lst), x_2_lst, mk_list_resulttype(t_3_lst))) + -- fun_with_locals: `%%%%`(C, x_1_lst, mk_localtype_localtype(SET_init, t)*{t <- t_lst}, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 rule sub{C : context, instr_lst : instr*, it' : instrtype, it : instrtype}: @@ -7394,33 +9253,34 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:630.1-633.33 rule frame{C : context, instr_lst : instr*, t_lst : valtype*, t_1_lst : valtype*, x_lst : idx*, t_2_lst : valtype*}: - `%|-%:%`(C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_lst ++ t_1_lst), x_lst, `%`_resulttype(t_lst ++ t_2_lst))) - -- Instrs_ok: `%|-%:%`(C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_lst)) + `%|-%:%`(C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ t_1_lst), x_lst, mk_list_resulttype(t_lst ++ t_2_lst))) + -- Instrs_ok: `%|-%:%`(C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_lst)) -- wf_context: `%`(C) -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ t_1_lst), x_lst, `%`_resulttype(t_lst ++ t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ t_1_lst), x_lst, mk_list_resulttype(t_lst ++ t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) } ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Expr_ok: `%|-%:%`(context, expr, resulttype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule mk_Expr_ok{C : context, instr_lst : instr*, t_lst : valtype*}: - `%|-%:%`(C, instr_lst, `%`_resulttype(t_lst)) - -- Instrs_ok: `%|-%:%`(C, instr_lst, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + `%|-%:%`(C, instr_lst, mk_list_resulttype(t_lst)) + -- Instrs_ok: `%|-%:%`(C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) -- wf_context: `%`(C) -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule mk_Nondefaultable{t : valtype}: `|-%NONDEFAULTABLE`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) + -- if ($default_(t) =/= ?()) -- wf_valtype: `%`(t) + -- (wf_val: `%`(iter))?{iter <- !($default_(t))} ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7438,80 +9298,80 @@ relation Instr_const: `%|-%CONST`(context, instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule ref_null{C : context, ht : heaptype}: - `%|-%CONST`(C, `REF.NULL`_instr(ht)) + `%|-%CONST`(C, REF_NULL_instr(ht)) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.NULL`_instr(ht)) + -- wf_instr: `%`(REF_NULL_instr(ht)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule ref_i31{C : context}: - `%|-%CONST`(C, `REF.I31`_instr) + `%|-%CONST`(C, REF_I31_instr) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.I31`_instr) + -- wf_instr: `%`(REF_I31_instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule ref_func{C : context, x : idx}: - `%|-%CONST`(C, `REF.FUNC`_instr(x)) + `%|-%CONST`(C, REF_FUNC_instr(x)) -- wf_context: `%`(C) - -- wf_instr: `%`(`REF.FUNC`_instr(x)) + -- wf_instr: `%`(REF_FUNC_instr(x)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule struct_new{C : context, x : idx}: - `%|-%CONST`(C, `STRUCT.NEW`_instr(x)) + `%|-%CONST`(C, STRUCT_NEW_instr(x)) -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) + -- wf_instr: `%`(STRUCT_NEW_instr(x)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule struct_new_default{C : context, x : idx}: - `%|-%CONST`(C, `STRUCT.NEW_DEFAULT`_instr(x)) + `%|-%CONST`(C, STRUCT_NEW_DEFAULT_instr(x)) -- wf_context: `%`(C) - -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) + -- wf_instr: `%`(STRUCT_NEW_DEFAULT_instr(x)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule array_new{C : context, x : idx}: - `%|-%CONST`(C, `ARRAY.NEW`_instr(x)) + `%|-%CONST`(C, ARRAY_NEW_instr(x)) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) + -- wf_instr: `%`(ARRAY_NEW_instr(x)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule array_new_default{C : context, x : idx}: - `%|-%CONST`(C, `ARRAY.NEW_DEFAULT`_instr(x)) + `%|-%CONST`(C, ARRAY_NEW_DEFAULT_instr(x)) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) + -- wf_instr: `%`(ARRAY_NEW_DEFAULT_instr(x)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule array_new_fixed{C : context, x : idx, v_n : n}: - `%|-%CONST`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) + `%|-%CONST`(C, ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) -- wf_context: `%`(C) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule any_convert_extern{C : context}: - `%|-%CONST`(C, `ANY.CONVERT_EXTERN`_instr) + `%|-%CONST`(C, ANY_CONVERT_EXTERN_instr) -- wf_context: `%`(C) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) + -- wf_instr: `%`(ANY_CONVERT_EXTERN_instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule extern_convert_any{C : context}: - `%|-%CONST`(C, `EXTERN.CONVERT_ANY`_instr) + `%|-%CONST`(C, EXTERN_CONVERT_ANY_instr) -- wf_context: `%`(C) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) + -- wf_instr: `%`(EXTERN_CONVERT_ANY_instr) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule global_get{C : context, x : idx, t : valtype}: - `%|-%CONST`(C, `GLOBAL.GET`_instr(x)) + `%|-%CONST`(C, GLOBAL_GET_instr(x)) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = mk_globaltype_globaltype(?(), t)) -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) - -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) + -- wf_instr: `%`(GLOBAL_GET_instr(x)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule binop{C : context, v_Inn : Inn, binop : binop_}: `%|-%CONST`(C, BINOP_instr($numtype_addrtype(v_Inn), binop)) - -- if (|[I32_Inn I64_Inn]| > 0) -- if (v_Inn <- [I32_Inn I64_Inn]) - -- if (|[mk_binop__0_binop_(v_Inn, ADD_binop_Inn) mk_binop__0_binop_(v_Inn, SUB_binop_Inn) mk_binop__0_binop_(v_Inn, MUL_binop_Inn)]| > 0) + -- if (|[I32_Inn I64_Inn]| > 0) -- if (binop <- [mk_binop__0_binop_(v_Inn, ADD_binop_Inn) mk_binop__0_binop_(v_Inn, SUB_binop_Inn) mk_binop__0_binop_(v_Inn, MUL_binop_Inn)]) + -- if (|[mk_binop__0_binop_(v_Inn, ADD_binop_Inn) mk_binop__0_binop_(v_Inn, SUB_binop_Inn) mk_binop__0_binop_(v_Inn, MUL_binop_Inn)]| > 0) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr($numtype_addrtype(v_Inn), binop)) -- wf_binop_: `%%`($numtype_addrtype(v_Inn), mk_binop__0_binop_(v_Inn, ADD_binop_Inn)) @@ -7532,7 +9392,7 @@ relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule mk_Expr_ok_const{C : context, v_expr : expr, t : valtype}: `%|-%:%CONST`(C, v_expr, t) - -- Expr_ok: `%|-%:%`(C, v_expr, `%`_resulttype([t])) + -- Expr_ok: `%|-%:%`(C, v_expr, mk_list_resulttype([t])) -- Expr_const: `%|-%CONST`(C, v_expr) -- wf_context: `%`(C) -- (wf_instr: `%`(v_expr))*{v_expr <- v_expr} @@ -7541,23 +9401,26 @@ relation Expr_ok_const: `%|-%:%CONST`(context, expr, valtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Type_ok: `%|-%:%`(context, type, deftype*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule mk_Type_ok{C : context, v_rectype : rectype, dt_lst : deftype*, x : idx}: + rule mk_Type_ok{C : context, v_rectype : rectype, dt_lst : deftype*, x : idx, var_0 : deftype*}: `%|-%:%`(C, TYPE_type(v_rectype), dt_lst) -- if ($proj_uN_0(x).0 = |C.TYPES_context|) - -- if (dt_lst = $rolldt(x, v_rectype)) + -- if (dt_lst = var_0) -- Rectype_ok: `%|-%:%`(C +++ {TYPES dt_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, v_rectype, OK_oktypeidx(x)) -- wf_context: `%`(C) -- wf_context: `%`({TYPES dt_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_oktypeidx: `%`(OK_oktypeidx(x)) + -- fun_rolldt: `%%%`(x, v_rectype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Tag_ok: `%|-%:%`(context, tag, tagtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule mk_Tag_ok{C : context, v_tagtype : tagtype}: - `%|-%:%`(C, TAG_tag(v_tagtype), $clos_tagtype(C, v_tagtype)) + rule mk_Tag_ok{C : context, v_tagtype : tagtype, var_0 : tagtype}: + `%|-%:%`(C, TAG_tag(v_tagtype), var_0) -- Tagtype_ok: `%|-%:OK`(C, v_tagtype) -- wf_context: `%`(C) + -- wf_typeuse: `%`(var_0) -- wf_tag: `%`(TAG_tag(v_tagtype)) + -- fun_clos_tagtype: `%%%`(C, v_tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7565,11 +9428,11 @@ relation Global_ok: `%|-%:%`(context, global, globaltype) rule mk_Global_ok{C : context, v_globaltype : globaltype, v_expr : expr, t : valtype}: `%|-%:%`(C, GLOBAL_global(v_globaltype, v_expr), v_globaltype) -- Globaltype_ok: `%|-%:OK`(C, v_globaltype) - -- if (v_globaltype = `%%`_globaltype(?(MUT_mut), t)) + -- if (v_globaltype = mk_globaltype_globaltype(?(MUT_mut), t)) -- Expr_ok_const: `%|-%:%CONST`(C, v_expr, t) -- wf_context: `%`(C) -- wf_global: `%`(GLOBAL_global(v_globaltype, v_expr)) - -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(MUT_mut), t)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Mem_ok: `%|-%:%`(context, mem, memtype) @@ -7586,44 +9449,44 @@ relation Table_ok: `%|-%:%`(context, table, tabletype) rule mk_Table_ok{C : context, v_tabletype : tabletype, v_expr : expr, at : addrtype, lim : limits, rt : reftype}: `%|-%:%`(C, TABLE_table(v_tabletype, v_expr), v_tabletype) -- Tabletype_ok: `%|-%:OK`(C, v_tabletype) - -- if (v_tabletype = `%%%`_tabletype(at, lim, rt)) + -- if (v_tabletype = mk_tabletype_tabletype(at, lim, rt)) -- Expr_ok_const: `%|-%:%CONST`(C, v_expr, $valtype_reftype(rt)) -- wf_context: `%`(C) -- wf_table: `%`(TABLE_table(v_tabletype, v_expr)) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Local_ok: `%|-%:%`(context, local, localtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule set{C : context, t : valtype}: - `%|-%:%`(C, LOCAL_local(t), `%%`_localtype(SET_init, t)) + `%|-%:%`(C, LOCAL_local(t), mk_localtype_localtype(SET_init, t)) -- Defaultable: `|-%DEFAULTABLE`(t) -- wf_context: `%`(C) -- wf_local: `%`(LOCAL_local(t)) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) + -- wf_localtype: `%`(mk_localtype_localtype(SET_init, t)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule unset{C : context, t : valtype}: - `%|-%:%`(C, LOCAL_local(t), `%%`_localtype(UNSET_init, t)) + `%|-%:%`(C, LOCAL_local(t), mk_localtype_localtype(UNSET_init, t)) -- Nondefaultable: `|-%NONDEFAULTABLE`(t) -- wf_context: `%`(C) -- wf_local: `%`(LOCAL_local(t)) - -- wf_localtype: `%`(`%%`_localtype(UNSET_init, t)) + -- wf_localtype: `%`(mk_localtype_localtype(UNSET_init, t)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Func_ok: `%|-%:%`(context, func, deftype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mk_Func_ok{C : context, x : idx, local_lst : local*, v_expr : expr, t_1_lst : valtype*, t_2_lst : valtype*, lct_lst : localtype*}: `%|-%:%`(C, FUNC_func(x, local_lst, v_expr), C.TYPES_context[$proj_uN_0(x).0]) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) - -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- if (|lct_lst| = |local_lst|) -- (Local_ok: `%|-%:%`(C, v_local, lct))*{lct <- lct_lst, v_local <- local_lst} - -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- t_1_lst} ++ lct_lst, LABELS [`%`_resulttype(t_2_lst)], RETURN ?(`%`_resulttype(t_2_lst)), REFS [], RECS []}, v_expr, `%`_resulttype(t_2_lst)) + -- if (|lct_lst| = |local_lst|) + -- Expr_ok: `%|-%:%`(C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS mk_localtype_localtype(SET_init, t_1)*{t_1 <- t_1_lst} ++ lct_lst, LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(mk_list_resulttype(t_2_lst)), REFS [], RECS []}, v_expr, mk_list_resulttype(t_2_lst)) -- wf_context: `%`(C) -- wf_func: `%`(FUNC_func(x, local_lst, v_expr)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS `%%`_localtype(SET_init, t_1)*{t_1 <- t_1_lst} ++ lct_lst, LABELS [`%`_resulttype(t_2_lst)], RETURN ?(`%`_resulttype(t_2_lst)), REFS [], RECS []}) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS mk_localtype_localtype(SET_init, t_1)*{t_1 <- t_1_lst} ++ lct_lst, LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(mk_list_resulttype(t_2_lst)), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Datamode_ok: `%|-%:%`(context, datamode, datatype) @@ -7636,8 +9499,8 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, v_expr : expr, at : addrtype, lim : limits}: `%|-%:%`(C, ACTIVE_datamode(x, v_expr), OK_datatype) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- Expr_ok_const: `%|-%:%CONST`(C, v_expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, v_expr)) @@ -7671,14 +9534,14 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule active{C : context, x : idx, v_expr : expr, rt : reftype, at : addrtype, lim : limits, rt' : reftype}: `%|-%:%`(C, ACTIVE_elemmode(x, v_expr), rt) + -- if (C.TABLES_context[$proj_uN_0(x).0] = mk_tabletype_tabletype(at, lim, rt')) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) - -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt')) -- Reftype_sub: `%|-%<:%`(C, rt, rt') -- Expr_ok_const: `%|-%:%CONST`(C, v_expr, $valtype_addrtype(at)) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, v_expr)) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt')) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt')) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Elem_ok: `%|-%:%`(context, elem, elemtype) @@ -7696,28 +9559,30 @@ relation Start_ok: `%|-%:OK`(context, start) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mk_Start_ok{C : context, x : idx}: `%|-%:OK`(C, START_start(x)) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(mk_list_resulttype([]), mk_list_resulttype([]))) -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) - -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype([]), mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Import_ok: `%|-%:%`(context, import, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule mk_Import_ok{C : context, name_1 : name, name_2 : name, xt : externtype}: - `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), $clos_externtype(C, xt)) + rule mk_Import_ok{C : context, name_1 : name, name_2 : name, xt : externtype, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) -- Externtype_ok: `%|-%:OK`(C, xt) -- wf_context: `%`(C) + -- wf_externtype: `%`(var_0) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule tag{C : context, x : idx, jt : tagtype}: `%|-%:%`(C, TAG_externidx(x), TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) @@ -7725,8 +9590,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule global{C : context, x : idx, gt : globaltype}: `%|-%:%`(C, GLOBAL_externidx(x), GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) @@ -7734,8 +9599,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule mem{C : context, x : idx, mt : memtype}: `%|-%:%`(C, MEM_externidx(x), MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) @@ -7743,8 +9608,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule table{C : context, x : idx, tt : tabletype}: `%|-%:%`(C, TABLE_externidx(x), TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) @@ -7752,8 +9617,8 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule func{C : context, x : idx, dt : deftype}: `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) @@ -7811,13 +9676,13 @@ relation Types_ok: `%|-%:%`(context, type*, deftype*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec syntax nonfuncs = - | `%%%%%%`(global_lst : global*, mem_lst : mem*, table_lst : table*, elem_lst : elem*, start_opt : start?, export_lst : export*) + | mk_nonfuncs(global_lst : global*, mem_lst : mem*, table_lst : table*, elem_lst : elem*, start_opt : start?, export_lst : export*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation wf_nonfuncs: `%`(nonfuncs) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec rule nonfuncs_case_0{global_lst : global*, mem_lst : mem*, table_lst : table*, elem_lst : elem*, start_opt : start?, export_lst : export*}: - `%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst)) + `%`(mk_nonfuncs_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst)) -- (wf_global: `%`(v_global))*{v_global <- global_lst} -- (wf_mem: `%`(v_mem))*{v_mem <- mem_lst} -- (wf_table: `%`(v_table))*{v_table <- table_lst} @@ -7826,192 +9691,403 @@ relation wf_nonfuncs: `%`(nonfuncs) -- (wf_export: `%`(v_export))*{v_export <- export_lst} ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec -def $funcidx_nonfuncs(v_nonfuncs : nonfuncs) : funcidx* +relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - def $funcidx_nonfuncs{global_lst : global*, mem_lst : mem*, table_lst : table*, elem_lst : elem*, start_opt : start?, export_lst : export*}(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst)) = $funcidx_module(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list([]), `%`_list([]), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) - -- wf_module: `%`(MODULE_module(`%`_list([]), `%`_list([]), `%`_list([]), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list([]), `%`_list([]), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) + rule fun_funcidx_nonfuncs_case_0{global_lst : global*, mem_lst : mem*, table_lst : table*, elem_lst : elem*, start_opt : start?, export_lst : export*, var_0 : funcidx*}: + `%%`(mk_nonfuncs_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_0) + -- fun_funcidx_module: `%%`(MODULE_module(mk_list_list([]), mk_list_list([]), mk_list_list([]), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list([]), mk_list_list([]), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)), var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec - rule mk_Module_ok{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, C : context, xt_I_lst : externtype*, xt_E_lst : externtype*, dt'_lst : deftype*, C' : context, jt_lst : tagtype*, gt_lst : globaltype*, mt_lst : memtype*, tt_lst : tabletype*, dt_lst : deftype*, ok_lst : datatype*, rt_lst : reftype*, nm_lst : name*, jt_I_lst : tagtype*, mt_I_lst : memtype*, tt_I_lst : tabletype*, gt_I_lst : globaltype*, dt_I_lst : deftype*, x_lst : idx*}: - `|-%:%`(MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst)), $clos_moduletype(C, `%->%`_moduletype(xt_I_lst, xt_E_lst))) + rule mk_Module_ok{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, C : context, xt_I_lst : externtype*, xt_E_lst : externtype*, dt'_lst : deftype*, C' : context, jt_lst : tagtype*, gt_lst : globaltype*, mt_lst : memtype*, tt_lst : tabletype*, dt_lst : deftype*, ok_lst : datatype*, rt_lst : reftype*, nm_lst : name*, jt_I_lst : tagtype*, mt_I_lst : memtype*, tt_I_lst : tabletype*, gt_I_lst : globaltype*, dt_I_lst : deftype*, x_lst : idx*, var_6 : deftype*, var_5 : tabletype*, var_4 : memtype*, var_3 : globaltype*, var_2 : tagtype*, var_1 : funcidx*, var_0 : moduletype}: + `|-%:%`(MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)), var_0) -- Types_ok: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, type_lst, dt'_lst) - -- if (|import_lst| = |xt_I_lst|) -- (Import_ok: `%|-%:%`({TYPES dt'_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, v_import, xt_I))*{v_import <- import_lst, xt_I <- xt_I_lst} - -- if (|jt_lst| = |tag_lst|) + -- if (|import_lst| = |xt_I_lst|) -- (Tag_ok: `%|-%:%`(C', v_tag, jt))*{jt <- jt_lst, v_tag <- tag_lst} + -- if (|jt_lst| = |tag_lst|) -- Globals_ok: `%|-%:%`(C', global_lst, gt_lst) - -- if (|mem_lst| = |mt_lst|) -- (Mem_ok: `%|-%:%`(C', v_mem, mt))*{v_mem <- mem_lst, mt <- mt_lst} - -- if (|table_lst| = |tt_lst|) + -- if (|mem_lst| = |mt_lst|) -- (Table_ok: `%|-%:%`(C', v_table, tt))*{v_table <- table_lst, tt <- tt_lst} - -- if (|dt_lst| = |func_lst|) + -- if (|table_lst| = |tt_lst|) -- (Func_ok: `%|-%:%`(C, v_func, dt))*{dt <- dt_lst, v_func <- func_lst} - -- if (|data_lst| = |ok_lst|) + -- if (|dt_lst| = |func_lst|) -- (Data_ok: `%|-%:%`(C, v_data, ok))*{v_data <- data_lst, ok <- ok_lst} - -- if (|elem_lst| = |rt_lst|) + -- if (|data_lst| = |ok_lst|) -- (Elem_ok: `%|-%:%`(C, v_elem, rt))*{v_elem <- elem_lst, rt <- rt_lst} + -- if (|elem_lst| = |rt_lst|) -- (Start_ok: `%|-%:OK`(C, v_start))?{v_start <- start_opt} + -- (Export_ok: `%|-%:%%`(C, v_export, nm, xt_E))*{v_export <- export_lst, nm <- nm_lst, xt_E <- xt_E_lst} -- if (|export_lst| = |nm_lst|) -- if (|export_lst| = |xt_E_lst|) - -- (Export_ok: `%|-%:%%`(C, v_export, nm, xt_E))*{v_export <- export_lst, nm <- nm_lst, xt_E <- xt_E_lst} -- if $disjoint_(syntax name, nm_lst) -- if (C = C' +++ {TYPES [], TAGS jt_I_lst ++ jt_lst, GLOBALS gt_lst, MEMS mt_I_lst ++ mt_lst, TABLES tt_I_lst ++ tt_lst, FUNCS [], DATAS ok_lst, ELEMS rt_lst, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- if (C' = {TYPES dt'_lst, TAGS [], GLOBALS gt_I_lst, MEMS [], TABLES [], FUNCS dt_I_lst ++ dt_lst, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x_lst, RECS []}) - -- if (x_lst = $funcidx_nonfuncs(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst))) - -- if (jt_I_lst = $tagsxt(xt_I_lst)) - -- if (gt_I_lst = $globalsxt(xt_I_lst)) - -- if (mt_I_lst = $memsxt(xt_I_lst)) - -- if (tt_I_lst = $tablesxt(xt_I_lst)) - -- if (dt_I_lst = $funcsxt(xt_I_lst)) + -- if (x_lst = var_1) + -- if (jt_I_lst = var_2) + -- if (gt_I_lst = var_3) + -- if (mt_I_lst = var_4) + -- if (tt_I_lst = var_5) + -- if (dt_I_lst = var_6) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- nm_lst} - -- wf_module: `%`(MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I_lst, xt_E_lst)) + -- wf_moduletype: `%`(var_0) + -- (wf_uN: `%%`(32, iter))*{iter <- var_1} + -- (wf_typeuse: `%`(iter))*{iter <- var_2} + -- (wf_globaltype: `%`(iter))*{iter <- var_3} + -- (wf_memtype: `%`(iter))*{iter <- var_4} + -- (wf_tabletype: `%`(iter))*{iter <- var_5} + -- wf_module: `%`(MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst))) + -- wf_moduletype: `%`(mk_moduletype_moduletype(xt_I_lst, xt_E_lst)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES dt'_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES [], TAGS jt_I_lst ++ jt_lst, GLOBALS gt_lst, MEMS mt_I_lst ++ mt_lst, TABLES tt_I_lst ++ tt_lst, FUNCS [], DATAS ok_lst, ELEMS rt_lst, LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- wf_context: `%`({TYPES dt'_lst, TAGS [], GLOBALS gt_I_lst, MEMS [], TABLES [], FUNCS dt_I_lst ++ dt_lst, DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS x_lst, RECS []}) - -- wf_nonfuncs: `%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst)) + -- wf_nonfuncs: `%`(mk_nonfuncs_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst)) + -- fun_funcsxt: `%%`(xt_I_lst, var_6) + -- fun_tablesxt: `%%`(xt_I_lst, var_5) + -- fun_memsxt: `%%`(xt_I_lst, var_4) + -- fun_globalsxt: `%%`(xt_I_lst, var_3) + -- fun_tagsxt: `%%`(xt_I_lst, var_2) + -- fun_funcidx_nonfuncs: `%%`(mk_nonfuncs_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_1) + -- fun_clos_moduletype: `%%%`(C, mk_moduletype_moduletype(xt_I_lst, xt_E_lst), var_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed2 = - | `%`(i : nat) + | mk_relaxed2(i : nat) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $proj_relaxed2_0(x : relaxed2) : (nat) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $proj_relaxed2_0{v_num_0 : nat}(`%`_relaxed2(v_num_0)) = (v_num_0) + def $proj_relaxed2_0{v_num_0 : nat}(mk_relaxed2_relaxed2(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec relation wf_relaxed2: `%`(relaxed2) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec rule relaxed2_case_0{i : nat}: - `%`(`%`_relaxed2(i)) + `%`(mk_relaxed2_relaxed2(i)) -- if ((i = 0) \/ (i = 1)) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed4 = - | `%`(i : nat) + | mk_relaxed4(i : nat) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $proj_relaxed4_0(x : relaxed4) : (nat) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $proj_relaxed4_0{v_num_0 : nat}(`%`_relaxed4(v_num_0)) = (v_num_0) + def $proj_relaxed4_0{v_num_0 : nat}(mk_relaxed4_relaxed4(v_num_0)) = (v_num_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec relation wf_relaxed4: `%`(relaxed4) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec rule relaxed4_case_0{i : nat}: - `%`(`%`_relaxed4(i)) + `%`(mk_relaxed4_relaxed4(i)) -- if ((((i = 0) \/ (i = 1)) \/ (i = 2)) \/ (i = 3)) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $fun_relaxed2(v_relaxed2 : relaxed2, syntax X, X_0 : X, X_1 : X) : X +def $fun_relaxed2(v_relaxed2 : relaxed2, syntax r_X, v_X : r_X, v_X_0 : r_X) : r_X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $fun_relaxed2{i : relaxed2, syntax X, X_1 : X, X_2 : X}(i, syntax X, X_1, X_2) = (if $ND then [X_1 X_2][$proj_relaxed2_0(i).0] else [X_1 X_2][0]) + def $fun_relaxed2{i : relaxed2, syntax r_X, X_1 : r_X, X_2 : r_X}(i, syntax r_X, X_1, X_2) = (if $ND then [X_1 X_2][$proj_relaxed2_0(i).0] else [X_1 X_2][0]) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec -def $fun_relaxed4(v_relaxed4 : relaxed4, syntax X, X_0 : X, X_1 : X, X_2 : X, X_3 : X) : X +def $fun_relaxed4(v_relaxed4 : relaxed4, syntax r_X, v_X : r_X, v_X_0 : r_X, v_X_1 : r_X, v_X_2 : r_X) : r_X ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec - def $fun_relaxed4{i : relaxed4, syntax X, X_1 : X, X_2 : X, X_3 : X, X_4 : X}(i, syntax X, X_1, X_2, X_3, X_4) = (if $ND then [X_1 X_2 X_3 X_4][$proj_relaxed4_0(i).0] else [X_1 X_2 X_3 X_4][0]) + def $fun_relaxed4{i : relaxed4, syntax r_X, X_1 : r_X, X_2 : r_X, X_3 : r_X, X_4 : r_X}(i, syntax r_X, X_1, X_2, X_3, X_4) = (if $ND then [X_1 X_2 X_3 X_4][$proj_relaxed4_0(i).0] else [X_1 X_2 X_3 X_4][0]) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmadd : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmadd_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmadd_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_fmadd) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmin : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmin_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmin_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmin) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_fmax : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_fmax_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_fmax_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_fmax) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_idot : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_idot_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_idot_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_idot) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_iq15mulr : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_iq15mulr_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_iq15mulr_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_iq15mulr) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_u : relaxed4 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_u_is_wf: `%`(ret_val : relaxed4) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_u_is_wf_0{ret_val : relaxed4}: + `%`(ret_val) + -- if (ret_val = $R_trunc_u) + -- wf_relaxed4: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_trunc_s : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_trunc_s_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_trunc_s_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_trunc_s) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_swizzle : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_swizzle_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_swizzle_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_swizzle) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec def $R_laneselect : relaxed2 +;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec +relation R_laneselect_is_wf: `%`(ret_val : relaxed2) + ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec + rule R_laneselect_is_wf_0{ret_val : relaxed2}: + `%`(ret_val) + -- if (ret_val = $R_laneselect) + -- wf_relaxed2: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $s33_to_u32(v_s33 : s33) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibits_(v_N : N, v_iN : iN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibits__is_wf: `%%%`(v_N : N, v_iN : iN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibits__is_wf_0{v_N : N, v_iN : iN, ret_val : bit*}: + `%%%`(v_N, v_iN, ret_val) + -- wf_uN: `%%`(v_N, v_iN) + -- if (ret_val = $ibits_(v_N, v_iN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbits_(v_N : N, v_fN : fN) : bit* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbits__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : bit*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbits__is_wf_0{v_N : N, v_fN : fN, ret_val : bit*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fbits_(v_N, v_fN)) + -- (wf_bit: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ibytes_(v_N : N, v_iN : iN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ibytes__is_wf: `%%%`(v_N : N, v_iN : iN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ibytes__is_wf_0{v_N : N, v_iN : iN, ret_val : byte*}: + `%%%`(v_N, v_iN, ret_val) + -- wf_uN: `%%`(v_N, v_iN) + -- if (ret_val = $ibytes_(v_N, v_iN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fbytes_(v_N : N, v_fN : fN) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fbytes__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fbytes__is_wf_0{v_N : N, v_fN : fN, ret_val : byte*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fbytes_(v_N, v_fN)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $nbytes_(v_numtype : numtype, v_num_ : num_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation nbytes__is_wf: `%%%`(v_numtype : numtype, v_num_ : num_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule nbytes__is_wf_0{v_numtype : numtype, v_num_ : num_, ret_val : byte*}: + `%%%`(v_numtype, v_num_, ret_val) + -- wf_num_: `%%`(v_numtype, v_num_) + -- if (ret_val = $nbytes_(v_numtype, v_num_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $vbytes_(v_vectype : vectype, v_vec_ : vec_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation vbytes__is_wf: `%%%`(v_vectype : vectype, v_vec_ : vec_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule vbytes__is_wf_0{v_vectype : vectype, v_vec_ : vec_, ret_val : byte*}: + `%%%`(v_vectype, v_vec_, ret_val) + -- wf_uN: `%%`($vsize(v_vectype), v_vec_) + -- if (ret_val = $vbytes_(v_vectype, v_vec_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $zbytes_(v_storagetype : storagetype, v_lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zbytes__is_wf: `%%%`(v_storagetype : storagetype, v_lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zbytes__is_wf_0{v_storagetype : storagetype, v_lit_ : lit_, ret_val : byte*}: + `%%%`(v_storagetype, v_lit_, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- wf_lit_: `%%`(v_storagetype, v_lit_) + -- if (ret_val = $zbytes_(v_storagetype, v_lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cbytes_(v_Cnn : Cnn, v_lit_ : lit_) : byte* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cbytes__is_wf: `%%%`(v_Cnn : Cnn, v_lit_ : lit_, ret_val : byte*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cbytes__is_wf_0{v_Cnn : Cnn, v_lit_ : lit_, ret_val : byte*}: + `%%%`(v_Cnn, v_lit_, ret_val) + -- wf_lit_: `%%`($storagetype_Cnn(v_Cnn), v_lit_) + -- if (ret_val = $cbytes_(v_Cnn, v_lit_)) + -- (wf_byte: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibits_(v_N : N, var_0 : bit*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbits_(v_N : N, var_0 : bit*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbits__is_wf: `%%%`(v_N : N, var_0 : bit*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbits__is_wf_0{v_N : N, var_0 : bit*, ret_val : fN}: + `%%%`(v_N, var_0, ret_val) + -- (wf_bit: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbits_(v_N, var_0)) + -- wf_fN: `%%`(v_N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_ibytes_(v_N : N, var_0 : byte*) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_fbytes_(v_N : N, var_0 : byte*) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_fbytes__is_wf: `%%%`(v_N : N, var_0 : byte*, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_fbytes__is_wf_0{v_N : N, var_0 : byte*, ret_val : fN}: + `%%%`(v_N, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_fbytes_(v_N, var_0)) + -- wf_fN: `%%`(v_N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_nbytes_(v_numtype : numtype, var_0 : byte*) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_nbytes__is_wf: `%%%`(v_numtype : numtype, var_0 : byte*, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_nbytes__is_wf_0{v_numtype : numtype, var_0 : byte*, ret_val : num_}: + `%%%`(v_numtype, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_nbytes_(v_numtype, var_0)) + -- wf_num_: `%%`(v_numtype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_vbytes_(v_vectype : vectype, var_0 : byte*) : vec_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_zbytes_(v_storagetype : storagetype, var_0 : byte*) : lit_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation inv_zbytes__is_wf: `%%%`(v_storagetype : storagetype, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_zbytes__is_wf_0{v_storagetype : storagetype, var_0 : byte*, ret_val : lit_}: + `%%%`(v_storagetype, var_0, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_zbytes_(v_storagetype, var_0)) + -- wf_lit_: `%%`(v_storagetype, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inv_cbytes_(v_Cnn : Cnn, var_0 : byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(v_N : N, nat : nat) : int +relation inv_cbytes__is_wf: `%%%`(v_Cnn : Cnn, var_0 : byte*, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule inv_cbytes__is_wf_0{v_Cnn : Cnn, var_0 : byte*, ret_val : lit_}: + `%%%`(v_Cnn, var_0, ret_val) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $inv_cbytes_(v_Cnn, var_0)) + -- wf_lit_: `%%`($storagetype_Cnn(v_Cnn), ret_val) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_signed_: `%%%`(N, nat, int) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{v_N : nat, i : nat}(v_N, i) = (i : nat <:> int) + rule fun_signed__case_0{v_N : nat, i : nat}: + `%%%`(v_N, i, (i : nat <:> int)) -- if (i < (2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $signed_{v_N : nat, i : nat}(v_N, i) = ((i : nat <:> int) - ((2 ^ v_N) : nat <:> int)) + rule fun_signed__case_1{v_N : nat, i : nat}: + `%%%`(v_N, i, ((i : nat <:> int) - ((2 ^ v_N) : nat <:> int))) -- if (((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) <= i) /\ (i < (2 ^ v_N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inv_signed_(v_N : N, int : int) : nat +relation fun_inv_signed_: `%%%`(N, int, nat) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{v_N : nat, i : int}(v_N, i) = (i : int <:> nat) + rule fun_inv_signed__case_0{v_N : nat, i : int}: + `%%%`(v_N, i, (i : int <:> nat)) -- if (((0 : nat <:> int) <= i) /\ (i < ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inv_signed_{v_N : nat, i : int}(v_N, i) = ((i + ((2 ^ v_N) : nat <:> int)) : int <:> nat) + rule fun_inv_signed__case_1{v_N : nat, i : int}: + `%%%`(v_N, i, ((i + ((2 ^ v_N) : nat <:> int)) : int <:> nat)) -- if ((- ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= i) /\ (i < (0 : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -8036,23 +10112,25 @@ def $fun_sx(v_storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fun_zero(v_lanetype : lanetype) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, `%`_uN(0))) + def $fun_zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, mk_uN_uN(0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, `%`_uN(0))) + def $fun_zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, mk_uN_uN(0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, `%`_uN(0))) + def $fun_zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, mk_uN_uN(0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) - -- wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, `%`_uN(0))) + def $fun_zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, mk_uN_uN(0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fun_zero(F32_lanetype) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $fzero($size($numtype_Fnn(F32_Fnn)))))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fun_zero(F64_lanetype) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn))))) - -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $fzero($size($numtype_Fnn(F64_Fnn)))))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation zero_is_wf: `%%`(v_lanetype : lanetype, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule zero_is_wf_0{v_lanetype : lanetype, ret_val : lane_}: + `%%`(v_lanetype, ret_val) + -- if (ret_val = $fun_zero(v_lanetype)) + -- wf_lane_: `%%`(v_lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(v_bool : bool) : nat @@ -8080,13 +10158,13 @@ def $sat_s_(v_N : N, int : int) : int ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ineg_(v_N : N, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ineg_{v_N : nat, i_1 : uN}(v_N, i_1) = `%`_iN((((((2 ^ v_N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(v_N, `%`_uN((((((2 ^ v_N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat))) + def $ineg_{v_N : nat, i_1 : uN}(v_N, i_1) = mk_uN_iN((((((2 ^ v_N) : nat <:> int) - ($proj_uN_0(i_1).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iabs_(v_N : N, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iabs_{v_N : nat, i_1 : uN}(v_N, i_1) = (if ($signed_(v_N, $proj_uN_0(i_1).0) >= (0 : nat <:> int)) then i_1 else $ineg_(v_N, i_1)) + def $iabs_{v_N : nat, i_1 : uN, var_0 : int}(v_N, i_1) = (if (var_0 >= (0 : nat <:> int)) then i_1 else $ineg_(v_N, i_1)) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iclz_(v_N : N, v_iN : iN) : iN @@ -8098,61 +10176,81 @@ def $ictz_(v_N : N, v_iN : iN) : iN def $ipopcnt_(v_N : N, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $iextend_(v_N : N, v_M : M, v_sx : sx, v_iN : iN) : iN +relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{v_N : nat, v_M : nat, i : uN}(v_N, v_M, U_sx, i) = `%`_iN(($proj_uN_0(i).0 \ (2 ^ v_M))) - -- wf_uN: `%%`(v_N, `%`_uN(($proj_uN_0(i).0 \ (2 ^ v_M)))) + rule fun_iextend__case_0{v_N : nat, v_M : nat, i : uN}: + `%%%%%`(v_N, v_M, U_sx, i, mk_uN_iN(($proj_uN_0(i).0 \ (2 ^ v_M)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iextend_{v_N : nat, v_M : nat, i : uN}(v_N, v_M, S_sx, i) = `%`_iN($inv_signed_(v_N, $signed_(v_M, ($proj_uN_0(i).0 \ (2 ^ v_M))))) - -- wf_uN: `%%`(v_N, `%`_uN($inv_signed_(v_N, $signed_(v_M, ($proj_uN_0(i).0 \ (2 ^ v_M)))))) + rule fun_iextend__case_1{v_N : nat, v_M : nat, i : uN, var_1 : int, var_0 : nat}: + `%%%%%`(v_N, v_M, S_sx, i, mk_uN_iN(var_0)) + -- fun_signed_: `%%%`(v_M, ($proj_uN_0(i).0 \ (2 ^ v_M)), var_1) + -- fun_inv_signed_: `%%%`(v_N, var_1, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ v_N))) - -- wf_uN: `%%`(v_N, `%`_uN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ v_N)))) + def $iadd_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = mk_uN_iN((($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) \ (2 ^ v_N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = `%`_iN(((((((2 ^ v_N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat)) - -- wf_uN: `%%`(v_N, `%`_uN(((((((2 ^ v_N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat))) + def $isub_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = mk_uN_iN(((((((2 ^ v_N) + $proj_uN_0(i_1).0) : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)) \ ((2 ^ v_N) : nat <:> int)) : int <:> nat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imul_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imul_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = `%`_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ v_N))) - -- wf_uN: `%%`(v_N, `%`_uN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ v_N)))) + def $imul_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = mk_uN_iN((($proj_uN_0(i_1).0 * $proj_uN_0(i_2).0) \ (2 ^ v_N))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $idiv_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN? +relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{v_N : nat, i_1 : uN}(v_N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_0{v_N : nat, i_1 : uN}: + `%%%%%`(v_N, U_sx, i_1, mk_uN_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = ?(`%`_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) - -- wf_uN: `%%`(v_N, `%`_uN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat))) + rule fun_idiv__case_1{v_N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(v_N, U_sx, i_1, i_2, ?(mk_uN_iN(($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{v_N : nat, i_1 : uN}(v_N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_idiv__case_2{v_N : nat, i_1 : uN}: + `%%%%%`(v_N, S_sx, i_1, mk_uN_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = ?() - -- if ((($signed_(v_N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(v_N, $proj_uN_0(i_2).0) : int <:> rat)) = ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + rule fun_idiv__case_3{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}: + `%%%%%`(v_N, S_sx, i_1, i_2, ?()) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $idiv_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(v_N, $truncz((($signed_(v_N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(v_N, $proj_uN_0(i_2).0) : int <:> rat)))))) - -- wf_uN: `%%`(v_N, `%`_uN($inv_signed_(v_N, $truncz((($signed_(v_N, $proj_uN_0(i_1).0) : int <:> rat) / ($signed_(v_N, $proj_uN_0(i_2).0) : int <:> rat)))))) + rule fun_idiv__case_4{v_N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(v_N, S_sx, i_1, i_2, ?(mk_uN_iN(var_0))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(v_N, $truncz(((var_1 : int <:> rat) / (var_2 : int <:> rat))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $irem_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN? +relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{v_N : nat, i_1 : uN}(v_N, U_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_0{v_N : nat, i_1 : uN}: + `%%%%%`(v_N, U_sx, i_1, mk_uN_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = ?(`%`_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) - -- wf_uN: `%%`(v_N, `%`_uN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat))) + rule fun_irem__case_1{v_N : nat, i_1 : uN, i_2 : uN}: + `%%%%%`(v_N, U_sx, i_1, i_2, ?(mk_uN_iN(((($proj_uN_0(i_1).0 : nat <:> int) - (($proj_uN_0(i_2).0 * ($truncz((($proj_uN_0(i_1).0 : nat <:> rat) / ($proj_uN_0(i_2).0 : nat <:> rat))) : int <:> nat)) : nat <:> int)) : int <:> nat)))) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{v_N : nat, i_1 : uN}(v_N, S_sx, i_1, `%`_iN(0)) = ?() + rule fun_irem__case_2{v_N : nat, i_1 : uN}: + `%%%%%`(v_N, S_sx, i_1, mk_uN_iN(0), ?()) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $irem_{v_N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int}(v_N, S_sx, i_1, i_2) = ?(`%`_iN($inv_signed_(v_N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) - -- if ((j_1 = $signed_(v_N, $proj_uN_0(i_1).0)) /\ (j_2 = $signed_(v_N, $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(v_N, `%`_uN($inv_signed_(v_N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat)))))))) + rule fun_irem__case_3{v_N : nat, i_1 : uN, i_2 : uN, j_1 : int, j_2 : int, var_2 : int, var_1 : int, var_0 : nat}: + `%%%%%`(v_N, S_sx, i_1, i_2, ?(mk_uN_iN(var_0))) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(v_N, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat))))), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN @@ -8163,7 +10261,9 @@ def $imin_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN def $imin_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imin_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = (if ($signed_(v_N, $proj_uN_0(i_1).0) <= $signed_(v_N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imin_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = (if (var_0 <= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imax_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN @@ -8174,25 +10274,29 @@ def $imax_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN def $imax_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = i_2 -- if ($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $imax_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = (if ($signed_(v_N, $proj_uN_0(i_1).0) >= $signed_(v_N, $proj_uN_0(i_2).0)) then i_1 else i_2) + def $imax_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = (if (var_0 >= var_1) then i_1 else i_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_sat_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_iN($sat_u_(v_N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) - -- wf_uN: `%%`(v_N, `%`_uN($sat_u_(v_N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int)))) + def $iadd_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_iN($sat_u_(v_N, (($proj_uN_0(i_1).0 + $proj_uN_0(i_2).0) : nat <:> int))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $iadd_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(v_N, $sat_s_(v_N, ($signed_(v_N, $proj_uN_0(i_1).0) + $signed_(v_N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(v_N, `%`_uN($inv_signed_(v_N, $sat_s_(v_N, ($signed_(v_N, $proj_uN_0(i_1).0) + $signed_(v_N, $proj_uN_0(i_2).0)))))) + def $iadd_sat_{v_N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(v_N, S_sx, i_1, i_2) = mk_uN_iN(var_0) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(v_N, $sat_s_(v_N, (var_1 + var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $isub_sat_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_iN($sat_u_(v_N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) - -- wf_uN: `%%`(v_N, `%`_uN($sat_u_(v_N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int))))) + def $isub_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_iN($sat_u_(v_N, (($proj_uN_0(i_1).0 : nat <:> int) - ($proj_uN_0(i_2).0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $isub_sat_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_iN($inv_signed_(v_N, $sat_s_(v_N, ($signed_(v_N, $proj_uN_0(i_1).0) - $signed_(v_N, $proj_uN_0(i_2).0))))) - -- wf_uN: `%%`(v_N, `%`_uN($inv_signed_(v_N, $sat_s_(v_N, ($signed_(v_N, $proj_uN_0(i_1).0) - $signed_(v_N, $proj_uN_0(i_2).0)))))) + def $isub_sat_{v_N : nat, i_1 : uN, i_2 : uN, var_2 : int, var_1 : int, var_0 : nat}(v_N, S_sx, i_1, i_2) = mk_uN_iN(var_0) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_2) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_1) + -- fun_inv_signed_: `%%%`(v_N, $sat_s_(v_N, (var_1 - var_2)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iq15mulr_sat_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN @@ -8242,117 +10346,286 @@ def $irelaxed_laneselect_(v_N : N, v_iN : iN, v_iN_0 : iN, v_iN_1 : iN) : iN* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieqz_(v_N : N, v_iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ieqz_{v_N : nat, i_1 : uN}(v_N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 = 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 = 0)))) + def $ieqz_{v_N : nat, i_1 : uN}(v_N, i_1) = mk_uN_u32($bool(($proj_uN_0(i_1).0 = 0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $inez_(v_N : N, v_iN : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $inez_{v_N : nat, i_1 : uN}(v_N, i_1) = `%`_u32($bool(($proj_uN_0(i_1).0 =/= 0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 =/= 0)))) + def $inez_{v_N : nat, i_1 : uN}(v_N, i_1) = mk_uN_u32($bool(($proj_uN_0(i_1).0 =/= 0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ieq_(v_N : N, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ieq_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = `%`_u32($bool((i_1 = i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 = i_2)))) + def $ieq_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = mk_uN_u32($bool((i_1 = i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ine_(v_N : N, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ine_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = `%`_u32($bool((i_1 =/= i_2))) - -- wf_uN: `%%`(32, `%`_uN($bool((i_1 =/= i_2)))) + def $ine_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, i_1, i_2) = mk_uN_u32($bool((i_1 =/= i_2))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ilt_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0)))) + def $ilt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_u32($bool(($proj_uN_0(i_1).0 < $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ilt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(v_N, $proj_uN_0(i_1).0) < $signed_(v_N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(v_N, $proj_uN_0(i_1).0) < $signed_(v_N, $proj_uN_0(i_2).0))))) + def $ilt_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = mk_uN_u32($bool((var_0 < var_1))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $igt_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0)))) + def $igt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_u32($bool(($proj_uN_0(i_1).0 > $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $igt_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(v_N, $proj_uN_0(i_1).0) > $signed_(v_N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(v_N, $proj_uN_0(i_1).0) > $signed_(v_N, $proj_uN_0(i_2).0))))) + def $igt_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = mk_uN_u32($bool((var_0 > var_1))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ile_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0)))) + def $ile_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_u32($bool(($proj_uN_0(i_1).0 <= $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ile_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(v_N, $proj_uN_0(i_1).0) <= $signed_(v_N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(v_N, $proj_uN_0(i_1).0) <= $signed_(v_N, $proj_uN_0(i_2).0))))) + def $ile_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = mk_uN_u32($bool((var_0 <= var_1))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ige_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = `%`_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) - -- wf_uN: `%%`(32, `%`_uN($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0)))) + def $ige_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, U_sx, i_1, i_2) = mk_uN_u32($bool(($proj_uN_0(i_1).0 >= $proj_uN_0(i_2).0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $ige_{v_N : nat, i_1 : uN, i_2 : uN}(v_N, S_sx, i_1, i_2) = `%`_u32($bool(($signed_(v_N, $proj_uN_0(i_1).0) >= $signed_(v_N, $proj_uN_0(i_2).0)))) - -- wf_uN: `%%`(32, `%`_uN($bool(($signed_(v_N, $proj_uN_0(i_1).0) >= $signed_(v_N, $proj_uN_0(i_2).0))))) + def $ige_{v_N : nat, i_1 : uN, i_2 : uN, var_1 : int, var_0 : int}(v_N, S_sx, i_1, i_2) = mk_uN_u32($bool((var_0 >= var_1))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fabs_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fabs__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fabs__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fabs_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fneg_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fneg__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fneg__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fneg_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsqrt_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsqrt__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsqrt__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fsqrt_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fceil_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fceil__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fceil__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fceil_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ffloor_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ffloor__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ffloor__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $ffloor_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $ftrunc_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation ftrunc__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule ftrunc__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $ftrunc_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fnearest_(v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fnearest__is_wf: `%%%`(v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fnearest__is_wf_0{v_N : N, v_fN : fN, ret_val : fN*}: + `%%%`(v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- if (ret_val = $fnearest_(v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fadd_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fadd__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fadd__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fadd_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fsub_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fsub__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fsub__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fsub_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmul_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmul__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmul__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fmul_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fdiv_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fdiv__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fdiv__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fdiv_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmin_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmin__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmin__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fmin_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fmax_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fmax__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fmax__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fmax_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmin_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmin__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmin__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fpmin_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fpmax_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fpmax__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fpmax__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fpmax_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_min_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_min__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_min__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $frelaxed_min_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_max_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_max__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_max__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $frelaxed_max_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fcopysign_(v_N : N, v_fN : fN, v_fN_0 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fcopysign__is_wf: `%%%%`(v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fcopysign__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, ret_val : fN*}: + `%%%%`(v_N, v_fN, fN_0, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- if (ret_val = $fcopysign_(v_N, v_fN, fN_0)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $feq_(v_N : N, v_fN : fN, v_fN_0 : fN) : u32 @@ -8374,9 +10647,31 @@ def $fge_(v_N : N, v_fN : fN, v_fN_0 : fN) : u32 ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_madd_(v_N : N, v_fN : fN, v_fN_0 : fN, v_fN_1 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_madd__is_wf: `%%%%%`(v_N : N, v_fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_madd__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(v_N, v_fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- wf_fN: `%%`(v_N, fN_1) + -- if (ret_val = $frelaxed_madd_(v_N, v_fN, fN_0, fN_1)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $frelaxed_nmadd_(v_N : N, v_fN : fN, v_fN_0 : fN, v_fN_1 : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation frelaxed_nmadd__is_wf: `%%%%%`(v_N : N, v_fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule frelaxed_nmadd__is_wf_0{v_N : N, v_fN : fN, fN_0 : fN, fN_1 : fN, ret_val : fN*}: + `%%%%%`(v_N, v_fN, fN_0, fN_1, ret_val) + -- wf_fN: `%%`(v_N, v_fN) + -- wf_fN: `%%`(v_N, fN_0) + -- wf_fN: `%%`(v_N, fN_1) + -- if (ret_val = $frelaxed_nmadd_(v_N, v_fN, fN_0, fN_1)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $wrap__(v_M : M, v_N : N, v_iN : iN) : iN @@ -8395,38 +10690,77 @@ def $relaxed_trunc__(v_M : M, v_N : N, v_sx : sx, v_fN : fN) : iN? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $demote__(v_M : M, v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation demote___is_wf: `%%%%`(v_M : M, v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule demote___is_wf_0{v_M : M, v_N : N, v_fN : fN, ret_val : fN*}: + `%%%%`(v_M, v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_M, v_fN) + -- if (ret_val = $demote__(v_M, v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $promote__(v_M : M, v_N : N, v_fN : fN) : fN* +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation promote___is_wf: `%%%%`(v_M : M, v_N : N, v_fN : fN, ret_val : fN*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule promote___is_wf_0{v_M : M, v_N : N, v_fN : fN, ret_val : fN*}: + `%%%%`(v_M, v_N, v_fN, ret_val) + -- wf_fN: `%%`(v_M, v_fN) + -- if (ret_val = $promote__(v_M, v_N, v_fN)) + -- (wf_fN: `%%`(v_N, ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $convert__(v_M : M, v_N : N, v_sx : sx, v_iN : iN) : fN +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation convert___is_wf: `%%%%%`(v_M : M, v_N : N, v_sx : sx, v_iN : iN, ret_val : fN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule convert___is_wf_0{v_M : M, v_N : N, v_sx : sx, v_iN : iN, ret_val : fN}: + `%%%%%`(v_M, v_N, v_sx, v_iN, ret_val) + -- wf_uN: `%%`(v_M, v_iN) + -- if (ret_val = $convert__(v_M, v_N, v_sx, v_iN)) + -- wf_fN: `%%`(v_N, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $narrow__(v_M : M, v_N : N, v_sx : sx, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, v_num_ : num_) : num_ +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation reinterpret___is_wf: `%%%%`(numtype_1 : numtype, numtype_2 : numtype, v_num_ : num_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule reinterpret___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, v_num_ : num_, ret_val : num_}: + `%%%%`(numtype_1, numtype_2, v_num_, ret_val) + -- wf_num_: `%%`(numtype_1, v_num_) + -- if (ret_val = $reinterpret__(numtype_1, numtype_2, v_num_)) + -- wf_num_: `%%`(numtype_2, ret_val) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_(v_lanetype : lanetype, v_num_ : num_) : lane_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I32_lanetype, c) = mk_lane__0_lane_(I32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I32_numtype), mk_lane__0_lane_(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(I64_lanetype, c) = mk_lane__0_lane_(I64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(I64_numtype), mk_lane__0_lane_(I64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F32_lanetype, c) = mk_lane__0_lane_(F32_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F32_numtype), mk_lane__0_lane_(F32_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : num_}(F64_lanetype, c) = mk_lane__0_lane_(F64_numtype, c) - -- wf_lane_: `%%`($lanetype_numtype(F64_numtype), mk_lane__0_lane_(F64_numtype, c)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I8_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I8_packtype), mk_lane__1_lane_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lpacknum_{c : uN}(I16_lanetype, mk_num__0_num_(I32_Inn, c)) = mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lane_: `%%`($lanetype_packtype(I16_packtype), mk_lane__1_lane_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lpacknum__is_wf: `%%%`(v_lanetype : lanetype, v_num_ : num_, ret_val : lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lpacknum__is_wf_0{v_lanetype : lanetype, v_num_ : num_, ret_val : lane_}: + `%%%`(v_lanetype, v_num_, ret_val) + -- wf_num_: `%%`($lunpack(v_lanetype), v_num_) + -- if (ret_val = $lpacknum_(v_lanetype, v_num_)) + -- wf_lane_: `%%`(v_lanetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ @@ -8442,10 +10776,19 @@ def $cpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ def $cpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I8_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I8_packtype), mk_lit__2_lit_(I8_packtype, $wrap__($size($lunpack($lanetype_packtype(I8_packtype))), $psize(I8_packtype), c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cpacknum_{c : uN}(I16_storagetype, mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, c))) = mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c)) - -- wf_lit_: `%%`($storagetype_packtype(I16_packtype), mk_lit__2_lit_(I16_packtype, $wrap__($size($lunpack($lanetype_packtype(I16_packtype))), $psize(I16_packtype), c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cpacknum__is_wf: `%%%`(v_storagetype : storagetype, v_lit_ : lit_, ret_val : lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cpacknum__is_wf_0{v_storagetype : storagetype, v_lit_ : lit_, ret_val : lit_}: + `%%%`(v_storagetype, v_lit_, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(v_storagetype))), v_lit_) + -- if ($cunpack(v_storagetype) =/= ?()) + -- if (ret_val = $cpacknum_(v_storagetype, v_lit_)) + -- wf_lit_: `%%`(v_storagetype, ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_(v_lanetype : lanetype, v_lane_ : lane_) : num_ @@ -8459,10 +10802,17 @@ def $lunpacknum_(v_lanetype : lanetype, v_lane_ : lane_) : num_ def $lunpacknum_{c : num_}(F64_lanetype, mk_lane__0_lane_(F64_numtype, c)) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I8_lanetype, mk_lane__1_lane_(I8_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I8_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $lunpacknum_{c : uN}(I16_lanetype, mk_lane__1_lane_(I16_packtype, c)) = mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)) - -- wf_num_: `%%`($lunpack($lanetype_packtype(I16_packtype)), mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation lunpacknum__is_wf: `%%%`(v_lanetype : lanetype, v_lane_ : lane_, ret_val : num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule lunpacknum__is_wf_0{v_lanetype : lanetype, v_lane_ : lane_, ret_val : num_}: + `%%%`(v_lanetype, v_lane_, ret_val) + -- wf_lane_: `%%`(v_lanetype, v_lane_) + -- if (ret_val = $lunpacknum_(v_lanetype, v_lane_)) + -- wf_num_: `%%`($lunpack(v_lanetype), ret_val) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ @@ -8478,196 +10828,292 @@ def $cunpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ def $cunpacknum_{c : lit_}(V128_storagetype, c) = c ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I8_storagetype, mk_lit__2_lit_(I8_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I8_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), $size($lunpack($lanetype_packtype(I8_packtype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $cunpacknum_{c : uN}(I16_storagetype, mk_lit__2_lit_(I16_packtype, c)) = mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c))) - -- wf_lit_: `%%`($storagetype_consttype(!($cunpack($storagetype_packtype(I16_packtype)))), mk_lit__0_lit_(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), $size($lunpack($lanetype_packtype(I16_packtype))), U_sx, c)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fun_unop_(v_numtype : numtype, v_unop_ : unop_, v_num_ : num_) : num_* +relation cunpacknum__is_wf: `%%%`(v_storagetype : storagetype, v_lit_ : lit_, ret_val : lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule cunpacknum__is_wf_0{v_storagetype : storagetype, v_lit_ : lit_, ret_val : lit_}: + `%%%`(v_storagetype, v_lit_, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- wf_lit_: `%%`(v_storagetype, v_lit_) + -- if (ret_val = $cunpacknum_(v_storagetype, v_lit_)) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(v_storagetype))), ret_val) + -- if ($cunpack(v_storagetype) =/= ?()) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_0{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CLZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $iclz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule fun_unop__case_1{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $iclz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_2{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, CTZ_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ictz_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))) + rule fun_unop__case_3{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, CTZ_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ictz_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))) + rule fun_unop__case_4{i : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, $ipopcnt_($sizenn($numtype_addrtype(I32_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{v_M : nat, i : uN}(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(v_M))), mk_num__0_num_(I32_Inn, i)) = [mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), v_M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iextend_($sizenn($numtype_addrtype(I32_Inn)), v_M, S_sx, i))) + rule fun_unop__case_5{i : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, $ipopcnt_($sizenn($numtype_addrtype(I64_Inn)), i))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{v_M : nat, i : uN}(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(v_M))), mk_num__0_num_(I64_Inn, i)) = [mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), v_M, S_sx, i))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iextend_($sizenn($numtype_addrtype(I64_Inn)), v_M, S_sx, i))) + rule fun_unop__case_6{v_M : nat, i : uN, var_0 : uN}: + `%%%%`(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(mk_sz_sz(v_M))), mk_num__0_num_(I32_Inn, i), [mk_num__0_num_(I32_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#2)*{iter_0#2 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#1)))*{iter_0#1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_7{v_M : nat, i : uN, var_0 : uN}: + `%%%%`(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(v_M))), mk_num__0_num_(I64_Inn, i), [mk_num__0_num_(I64_Inn, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_M, S_sx, i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#4)*{iter_0#4 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#3)))*{iter_0#3 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_8{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_1)*{iter_0_1 <- $fabs_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#6)*{iter_0#6 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#5)))*{iter_0#5 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_9{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, ABS_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_2)*{iter_0_2 <- $fabs_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#8)*{iter_0#8 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#7)))*{iter_0#7 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_10{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEG_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_3)*{iter_0_3 <- $fneg_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#10)*{iter_0#10 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#9)))*{iter_0#9 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_11{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEG_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_4)*{iter_0_4 <- $fneg_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#12)*{iter_0#12 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#11)))*{iter_0#11 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_12{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_5)*{iter_0_5 <- $fsqrt_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#14)*{iter_0#14 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#13)))*{iter_0#13 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_13{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, SQRT_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_6)*{iter_0_6 <- $fsqrt_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#16)*{iter_0#16 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#15)))*{iter_0#15 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_14{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_7)*{iter_0_7 <- $fceil_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#18)*{iter_0#18 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#17)))*{iter_0#17 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_15{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, CEIL_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_8)*{iter_0_8 <- $fceil_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#20)*{iter_0#20 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#19)))*{iter_0#19 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_16{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_9)*{iter_0_9 <- $ffloor_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#22)*{iter_0#22 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#21)))*{iter_0#21 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_17{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, FLOOR_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_10)*{iter_0_10 <- $ffloor_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#24)*{iter_0#24 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#23)))*{iter_0#23 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_18{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_11)*{iter_0_11 <- $ftrunc_($sizenn($numtype_Fnn(F32_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f)) = mk_num__1_num_(F32_Fnn, iter_0#26)*{iter_0#26 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#25)))*{iter_0#25 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)} + rule fun_unop__case_19{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, TRUNC_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_12)*{iter_0_12 <- $ftrunc_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_unop_{f : fN}(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f)) = mk_num__1_num_(F64_Fnn, iter_0#28)*{iter_0#28 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#27)))*{iter_0#27 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)} + rule fun_unop__case_20{f : fN}: + `%%%%`(F32_numtype, mk_unop__1_unop_(F32_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F32_Fnn, f), mk_num__1_num_(F32_Fnn, iter_0_13)*{iter_0_13 <- $fnearest_($sizenn($numtype_Fnn(F32_Fnn)), f)}) -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fun_binop_(v_numtype : numtype, v_binop_ : binop_, v_num_ : num_, v_num__0 : num_) : num_* ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_unop__case_21{f : fN}: + `%%%%`(F64_numtype, mk_unop__1_unop_(F64_Fnn, NEAREST_unop_Fnn), mk_num__1_num_(F64_Fnn, f), mk_num__1_num_(F64_Fnn, iter_0_14)*{iter_0_14 <- $fnearest_($sizenn($numtype_Fnn(F64_Fnn)), f)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation unop__is_wf: `%%%%`(v_numtype : numtype, v_unop_ : unop_, v_num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule unop__is_wf_0{v_numtype : numtype, v_unop_ : unop_, v_num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%`(v_numtype, v_unop_, v_num_, ret_val) + -- wf_unop_: `%%`(v_numtype, v_unop_) + -- wf_num_: `%%`(v_numtype, v_num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(v_numtype, ret_val))*{ret_val <- ret_val} + -- fun_unop_: `%%%%`(v_numtype, v_unop_, v_num_, var_0) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_0{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iadd_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_binop__case_1{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iadd_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_2{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SUB_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $isub_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_3{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SUB_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $isub_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_4{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, MUL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $imul_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_5{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, MUL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $imul_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_6{v_sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0_15)*{iter_0_15 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, DIV_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#30)*{iter_0#30 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift($idiv_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2))} + rule fun_binop__case_7{v_sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0_16)*{iter_0_16 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, DIV_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#32)*{iter_0#32 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift($idiv_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2))} + rule fun_binop__case_8{v_sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), mk_num__0_num_(I32_Inn, iter_0_17)*{iter_0_17 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, REM_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = mk_num__0_num_(I32_Inn, iter_0#34)*{iter_0#34 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift($irem_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2))} + rule fun_binop__case_9{v_sx : sx, i_1 : uN, i_2 : uN, var_0 : iN?}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), mk_num__0_num_(I64_Inn, iter_0_18)*{iter_0_18 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, REM_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = mk_num__0_num_(I64_Inn, iter_0#36)*{iter_0#36 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift($irem_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2))} + rule fun_binop__case_10{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, AND_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $iand_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_11{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, AND_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $iand_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_12{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, OR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ior_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_13{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, OR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ior_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_14{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, XOR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ixor_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_15{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, XOR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ixor_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_16{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, mk_uN_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishl_($sizenn($numtype_addrtype(I32_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_17{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, mk_uN_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishl_($sizenn($numtype_addrtype(I64_Inn)), i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_18{v_sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, mk_uN_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, SHR_binop_Inn(v_sx)), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $ishr_($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_19{v_sx : sx, i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, mk_uN_u32($proj_uN_0(i_2).0)))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{v_sx : sx, i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, SHR_binop_Inn(v_sx)), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, `%`_u32($proj_uN_0(i_2).0)))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $ishr_($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, `%`_u32($proj_uN_0(i_2).0)))) + rule fun_binop__case_20{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTL_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotl_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_21{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTL_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotl_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_22{i_1 : uN, i_2 : uN}: + `%%%%%`(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2), [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I32_numtype, mk_binop__0_binop_(I32_Inn, ROTR_binop_Inn), mk_num__0_num_(I32_Inn, i_1), mk_num__0_num_(I32_Inn, i_2)) = [mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $irotr_($sizenn($numtype_addrtype(I32_Inn)), i_1, i_2))) + rule fun_binop__case_23{i_1 : uN, i_2 : uN}: + `%%%%%`(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2), [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{i_1 : uN, i_2 : uN}(I64_numtype, mk_binop__0_binop_(I64_Inn, ROTR_binop_Inn), mk_num__0_num_(I64_Inn, i_1), mk_num__0_num_(I64_Inn, i_2)) = [mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $irotr_($sizenn($numtype_addrtype(I64_Inn)), i_1, i_2))) + rule fun_binop__case_24{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_19)*{iter_0_19 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, ADD_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#38)*{iter_0#38 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#37)))*{iter_0#37 <- $fadd_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_25{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_20)*{iter_0_20 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, ADD_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#40)*{iter_0#40 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#39)))*{iter_0#39 <- $fadd_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_26{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_21)*{iter_0_21 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, SUB_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#42)*{iter_0#42 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#41)))*{iter_0#41 <- $fsub_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_27{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_22)*{iter_0_22 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, SUB_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#44)*{iter_0#44 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#43)))*{iter_0#43 <- $fsub_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_28{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_23)*{iter_0_23 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MUL_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#46)*{iter_0#46 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#45)))*{iter_0#45 <- $fmul_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_29{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_24)*{iter_0_24 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MUL_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#48)*{iter_0#48 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#47)))*{iter_0#47 <- $fmul_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_30{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_25)*{iter_0_25 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, DIV_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#50)*{iter_0#50 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#49)))*{iter_0#49 <- $fdiv_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_31{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_26)*{iter_0_26 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, DIV_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#52)*{iter_0#52 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#51)))*{iter_0#51 <- $fdiv_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_32{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_27)*{iter_0_27 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MIN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#54)*{iter_0#54 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#53)))*{iter_0#53 <- $fmin_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_33{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_28)*{iter_0_28 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MIN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#56)*{iter_0#56 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#55)))*{iter_0#55 <- $fmin_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_34{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_29)*{iter_0_29 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, MAX_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#58)*{iter_0#58 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#57)))*{iter_0#57 <- $fmax_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_35{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_30)*{iter_0_30 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, MAX_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#60)*{iter_0#60 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#59)))*{iter_0#59 <- $fmax_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule fun_binop__case_36{f_1 : fN, f_2 : fN}: + `%%%%%`(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2), mk_num__1_num_(F32_Fnn, iter_0_31)*{iter_0_31 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F32_numtype, mk_binop__1_binop_(F32_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, f_2)) = mk_num__1_num_(F32_Fnn, iter_0#62)*{iter_0#62 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#61)))*{iter_0#61 <- $fcopysign_($sizenn($numtype_Fnn(F32_Fnn)), f_1, f_2)} + rule fun_binop__case_37{f_1 : fN, f_2 : fN}: + `%%%%%`(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2), mk_num__1_num_(F64_Fnn, iter_0_32)*{iter_0_32 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)}) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation binop__is_wf: `%%%%%`(v_numtype : numtype, v_binop_ : binop_, v_num_ : num_, num__0 : num_, ret_val : num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_binop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_binop__1_binop_(F64_Fnn, COPYSIGN_binop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = mk_num__1_num_(F64_Fnn, iter_0#64)*{iter_0#64 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#63)))*{iter_0#63 <- $fcopysign_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2)} + rule binop__is_wf_0{v_numtype : numtype, v_binop_ : binop_, v_num_ : num_, num__0 : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(v_numtype, v_binop_, v_num_, num__0, ret_val) + -- wf_binop_: `%%`(v_numtype, v_binop_) + -- wf_num_: `%%`(v_numtype, v_num_) + -- wf_num_: `%%`(v_numtype, num__0) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(v_numtype, ret_val))*{ret_val <- ret_val} + -- fun_binop_: `%%%%%`(v_numtype, v_binop_, v_num_, num__0, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fun_testop_(v_numtype : numtype, v_testop_ : testop_, v_num_ : num_) : u32 @@ -8728,327 +11174,765 @@ def $fun_relop_(v_numtype : numtype, v_relop_ : relop_, v_num_ : num_, v_num__0 def $fun_relop_{f_1 : fN, f_2 : fN}(F64_numtype, mk_relop__1_relop_(F64_Fnn, GE_relop_Fnn), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, f_2)) = $fge_($sizenn($numtype_Fnn(F64_Fnn)), f_1, f_2) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fun_cvtop__(numtype_1 : numtype, numtype_2 : numtype, v_cvtop__ : cvtop__, v_num_ : num_) : num_* +relation fun_cvtop__: `%%%%%`(numtype, numtype, cvtop__, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))) + rule fun_cvtop___case_0{v_sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))) + rule fun_cvtop___case_1{v_sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))) + rule fun_cvtop___case_2{v_sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))) + rule fun_cvtop___case_3{v_sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, EXTEND_cvtop__Inn_1_Inn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $extend__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) + rule fun_cvtop___case_4{i_1 : uN}: + `%%%%%`(I32_numtype, I32_numtype, mk_cvtop___0_cvtop__(I32_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))) + rule fun_cvtop___case_5{i_1 : uN}: + `%%%%%`(I64_numtype, I32_numtype, mk_cvtop___0_cvtop__(I64_Inn, I32_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I32_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I32_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) + rule fun_cvtop___case_6{i_1 : uN}: + `%%%%%`(I32_numtype, I64_numtype, mk_cvtop___0_cvtop__(I32_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I32_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))] - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))) + rule fun_cvtop___case_7{i_1 : uN}: + `%%%%%`(I64_numtype, I64_numtype, mk_cvtop___0_cvtop__(I64_Inn, I64_Inn, WRAP_cvtop__Inn_1_Inn_2), mk_num__0_num_(I64_Inn, i_1), [mk_num__0_num_(I64_Inn, $wrap__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_addrtype(I64_Inn)), i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#66)*{iter_0#66 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#65)))*{iter_0#65 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} + rule fun_cvtop___case_8{v_sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0_33)*{iter_0_33 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#68)*{iter_0#68 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#67)))*{iter_0#67 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} + rule fun_cvtop___case_9{v_sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0_34)*{iter_0_34 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#70)*{iter_0#70 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#69)))*{iter_0#69 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} + rule fun_cvtop___case_10{v_sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0_35)*{iter_0_35 <- lift($trunc__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#72)*{iter_0#72 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#71)))*{iter_0#71 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} + rule fun_cvtop___case_11{v_sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0_36)*{iter_0_36 <- lift($trunc__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#74)*{iter_0#74 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#73)))*{iter_0#73 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} + rule fun_cvtop___case_12{v_sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0_37)*{iter_0_37 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I32_Inn, iter_0#76)*{iter_0#76 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#75)))*{iter_0#75 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))} + rule fun_cvtop___case_13{v_sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I32_Inn, iter_0_38)*{iter_0_38 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I32_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#78)*{iter_0#78 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#77)))*{iter_0#77 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} + rule fun_cvtop___case_14{v_sx : sx, f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F32_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0_39)*{iter_0_39 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__0_num_(I64_Inn, iter_0#80)*{iter_0#80 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} - -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#79)))*{iter_0#79 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))} + rule fun_cvtop___case_15{v_sx : sx, f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(v_sx)), mk_num__1_num_(F64_Fnn, f_1), mk_num__0_num_(I64_Inn, iter_0_40)*{iter_0_40 <- lift($trunc_sat__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_addrtype(I64_Inn)), v_sx, f_1))}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))) + rule fun_cvtop___case_16{v_sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))) + rule fun_cvtop___case_17{v_sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F32_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F32_Fnn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))) + rule fun_cvtop___case_18{v_sx : sx, i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I32_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I32_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{v_sx : sx, i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1)) = [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))] - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))) + rule fun_cvtop___case_19{v_sx : sx, i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, CONVERT_cvtop__Inn_1_Fnn_2(v_sx)), mk_num__0_num_(I64_Inn, i_1), [mk_num__1_num_(F64_Fnn, $convert__($sizenn1($numtype_addrtype(I64_Inn)), $sizenn2($numtype_Fnn(F64_Fnn)), v_sx, i_1))]) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#82)*{iter_0#82 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#81)))*{iter_0#81 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_20{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0_41)*{iter_0_41 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#84)*{iter_0#84 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#83)))*{iter_0#83 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_21{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0_42)*{iter_0_42 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#86)*{iter_0#86 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#85)))*{iter_0#85 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_22{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0_43)*{iter_0_43 <- $promote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#88)*{iter_0#88 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#87)))*{iter_0#87 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_23{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, PROMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0_44)*{iter_0_44 <- $promote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#90)*{iter_0#90 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#89)))*{iter_0#89 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_24{f_1 : fN}: + `%%%%%`(F32_numtype, F32_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0_45)*{iter_0_45 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F32_Fnn, iter_0#92)*{iter_0#92 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#91)))*{iter_0#91 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)} + rule fun_cvtop___case_25{f_1 : fN}: + `%%%%%`(F64_numtype, F32_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F32_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F32_Fnn, iter_0_46)*{iter_0_46 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F32_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#94)*{iter_0#94 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#93)))*{iter_0#93 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_26{f_1 : fN}: + `%%%%%`(F32_numtype, F64_numtype, mk_cvtop___3_cvtop__(F32_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F32_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0_47)*{iter_0_47 <- $demote__($sizenn1($numtype_Fnn(F32_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1)) = mk_num__1_num_(F64_Fnn, iter_0#96)*{iter_0#96 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} - -- (wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#95)))*{iter_0#95 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)} + rule fun_cvtop___case_27{f_1 : fN}: + `%%%%%`(F64_numtype, F64_numtype, mk_cvtop___3_cvtop__(F64_Fnn, F64_Fnn, DEMOTE_cvtop__Fnn_1_Fnn_2), mk_num__1_num_(F64_Fnn, f_1), mk_num__1_num_(F64_Fnn, iter_0_48)*{iter_0_48 <- $demote__($sizenn1($numtype_Fnn(F64_Fnn)), $sizenn2($numtype_Fnn(F64_Fnn)), f_1)}) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))] + rule fun_cvtop___case_28{i_1 : uN}: + `%%%%%`(I32_numtype, F32_numtype, mk_cvtop___1_cvtop__(I32_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I32_Inn, i_1))]) -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))] + rule fun_cvtop___case_29{i_1 : uN}: + `%%%%%`(I64_numtype, F32_numtype, mk_cvtop___1_cvtop__(I64_Inn, F32_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F32_Fnn), mk_num__0_num_(I64_Inn, i_1))]) -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F32_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))] + rule fun_cvtop___case_30{i_1 : uN}: + `%%%%%`(I32_numtype, F64_numtype, mk_cvtop___1_cvtop__(I32_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I32_Inn, i_1), [$reinterpret__($numtype_addrtype(I32_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I32_Inn, i_1))]) -- if ($size($numtype_addrtype(I32_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{i_1 : uN}(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1)) = [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))] + rule fun_cvtop___case_31{i_1 : uN}: + `%%%%%`(I64_numtype, F64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2), mk_num__0_num_(I64_Inn, i_1), [$reinterpret__($numtype_addrtype(I64_Inn), $numtype_Fnn(F64_Fnn), mk_num__0_num_(I64_Inn, i_1))]) -- if ($size($numtype_addrtype(I64_Inn)) = $size($numtype_Fnn(F64_Fnn))) - -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, i_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))] + rule fun_cvtop___case_32{f_1 : fN}: + `%%%%%`(F32_numtype, I32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F32_Fnn, f_1))]) -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))] + rule fun_cvtop___case_33{f_1 : fN}: + `%%%%%`(F64_numtype, I32_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I32_Inn), mk_num__1_num_(F64_Fnn, f_1))]) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I32_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))] + rule fun_cvtop___case_34{f_1 : fN}: + `%%%%%`(F32_numtype, I64_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F32_Fnn, f_1), [$reinterpret__($numtype_Fnn(F32_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F32_Fnn, f_1))]) -- if ($size($numtype_Fnn(F32_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, f_1)) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_cvtop__{f_1 : fN}(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1)) = [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))] + rule fun_cvtop___case_35{f_1 : fN}: + `%%%%%`(F64_numtype, I64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, REINTERPRET_cvtop__Fnn_1_Inn_2), mk_num__1_num_(F64_Fnn, f_1), [$reinterpret__($numtype_Fnn(F64_Fnn), $numtype_addrtype(I64_Inn), mk_num__1_num_(F64_Fnn, f_1))]) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) - -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation cvtop___is_wf: `%%%%%`(numtype_1 : numtype, numtype_2 : numtype, v_cvtop__ : cvtop__, v_num_ : num_, ret_val : num_*) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule cvtop___is_wf_0{numtype_1 : numtype, numtype_2 : numtype, v_cvtop__ : cvtop__, v_num_ : num_, ret_val : num_*, var_0 : num_*}: + `%%%%%`(numtype_1, numtype_2, v_cvtop__, v_num_, ret_val) + -- wf_cvtop__: `%%%`(numtype_1, numtype_2, v_cvtop__) + -- wf_num_: `%%`(numtype_1, v_num_) + -- if (ret_val = var_0) + -- (wf_num_: `%%`(numtype_2, ret_val))*{ret_val <- ret_val} + -- fun_cvtop__: `%%%%%`(numtype_1, numtype_2, v_cvtop__, v_num_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $lanes_(v_shape : shape, v_vec_ : vec_) : lane_* +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lanes__is_wf: `%%%`(v_shape : shape, v_vec_ : vec_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lanes__is_wf_0{v_shape : shape, v_vec_ : vec_, ret_val : lane_*}: + `%%%`(v_shape, v_vec_, ret_val) + -- wf_shape: `%`(v_shape) + -- wf_uN: `%%`(128, v_vec_) + -- if (ret_val = $lanes_(v_shape, v_vec_)) + -- (wf_lane_: `%%`($fun_lanetype(v_shape), ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $inv_lanes_(v_shape : shape, var_0 : lane_*) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $zeroop(shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__) : zero? +relation fun_zeroop: `%%%%`(shape, shape, vcvtop__, zero?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_0{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_1{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_2{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_3{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_4{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_5{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_6{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_7{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_8{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_9{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_10{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_11{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_12{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_13{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_14{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?() + rule fun_zeroop_case_15{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_16{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_17{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_18{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_19{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_20{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_21{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_22{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = ?() + rule fun_zeroop_case_23{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_24{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_25{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_26{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_27{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_28{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_29{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_30{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_31{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_32{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_33{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_34{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_35{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_36{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_37{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_38{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = zero_opt + rule fun_zeroop_case_39{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), zero_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?(v_zero) + rule fun_zeroop_case_40{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?(v_zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?(v_zero) + rule fun_zeroop_case_41{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?(v_zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?(v_zero) + rule fun_zeroop_case_42{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?(v_zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?(v_zero) + rule fun_zeroop_case_43{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?(v_zero)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $zeroop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?() + rule fun_zeroop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $halfop(shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__) : half? +relation fun_halfop: `%%%%`(shape, shape, vcvtop__, half?) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_0{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_1{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_2{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_3{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_4{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_5{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_6{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_7{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_8{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_9{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_10{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_11{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_12{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_13{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_14{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx))) = ?(v_half) + rule fun_halfop_case_15{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), ?(v_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_16{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_17{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_18{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_19{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_20{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_21{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_22{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx))) = half_opt + rule fun_halfop_case_23{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), half_opt) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_24{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_25{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_26{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_27{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_28{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_29{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_30{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_31{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_32{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_33{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_34{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_35{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_36{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I8_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_37{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I8_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_38{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I16_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt))) = ?() + rule fun_halfop_case_39{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I16_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?() + rule fun_halfop_case_40{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?() + rule fun_halfop_case_41{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?() + rule fun_halfop_case_42{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat, v_zero : zero}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero))) = ?() + rule fun_halfop_case_43{M_1 : nat, M_2 : nat, v_zero : zero, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(v_zero)), ?()) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_44{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_45{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_46{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $halfop{M_1 : nat, M_2 : nat}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) = ?(LOW_half) + rule fun_halfop_case_47{M_1 : nat, M_2 : nat, M_1_0 : nat, M_2_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), ?(LOW_half)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fun_half(v_half : half, nat : nat, nat_0 : nat) : nat @@ -9060,460 +11944,445 @@ def $fun_half(v_half : half, nat : nat, nat_0 : nat) : nat ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $iswizzle_lane_(v_N : N, var_0 : iN*, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $iswizzle_lane_{v_N : nat, c_lst : iN*, i : uN}(v_N, c_lst, i) = (if ($proj_uN_0(i).0 < |c_lst|) then c_lst[$proj_uN_0(i).0] else `%`_iN(0)) - -- wf_uN: `%%`(v_N, `%`_uN(0)) + def $iswizzle_lane_{v_N : nat, c_lst : iN*, i : uN}(v_N, c_lst, i) = (if ($proj_uN_0(i).0 < |c_lst|) then c_lst[$proj_uN_0(i).0] else mk_uN_iN(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $irelaxed_swizzle_lane_(v_N : N, var_0 : iN*, v_iN : iN) : iN ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $irelaxed_swizzle_lane_{v_N : nat, c_lst : iN*, i : uN}(v_N, c_lst, i) = (if ($proj_uN_0(i).0 < |c_lst|) then c_lst[$proj_uN_0(i).0] else (if ($signed_(v_N, $proj_uN_0(i).0) < (0 : nat <:> int)) then `%`_iN(0) else $fun_relaxed2($R_swizzle, syntax iN, `%`_iN(0), c_lst[($proj_uN_0(i).0 \ |c_lst|)]))) - -- wf_uN: `%%`(v_N, `%`_uN(0)) + def $irelaxed_swizzle_lane_{v_N : nat, c_lst : iN*, i : uN, var_0 : int}(v_N, c_lst, i) = (if ($proj_uN_0(i).0 < |c_lst|) then c_lst[$proj_uN_0(i).0] else (if (var_0 < (0 : nat <:> int)) then mk_uN_iN(0) else $fun_relaxed2($R_swizzle, syntax iN, mk_uN_iN(0), c_lst[($proj_uN_0(i).0 \ |c_lst|)]))) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivunop_(v_shape : shape, def $f_(v_N : N, v_iN : iN) : iN, v_vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#5)*{c#5 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#2)))*{c_1#2 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#4)))*{c#4 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#8)*{c#8 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#4)))*{c_1#4 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#7)))*{c#7 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#11)*{c#11 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#10)))*{c#10 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#14)*{c#14 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#8)))*{c_1#8 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#13)))*{c#13 <- c_lst} + def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_4)*{c_4 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_2)))*{c_1_2 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_6)*{c_6 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_4)))*{c_1_4 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_8)*{c_8 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_6)))*{c_1_6 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{v_M : nat, def $f_(v_N : N, v_iN : iN) : iN, v_1 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_10)*{c_10 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_8)))*{c_1_8 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvunop_(v_shape : shape, def $f_(v_N : N, v_fN : fN) : fN*, v_vec_ : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{v_M : nat, def $f_(v_N : N, v_fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), c_lst#2)*{c_lst#2 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_1) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#97))*{iter_0#97 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#10)))))}*{c_1#10 <- c_1_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#98))))*{iter_0#98 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#11)))))}*{c_1#11 <- c_1_lst} + def $fvunop_{v_M : nat, def $f_(v_N : N, v_fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), c_lst_2)*{c_lst_2 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_49))*{iter_0_49 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_10)))))}*{c_1_10 <- c_1_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_50))))*{iter_0_50 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_11)))))}*{c_1_11 <- c_1_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvunop_{v_M : nat, def $f_(v_N : N, v_fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), c_lst#4)*{c_lst#4 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_1) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#99))*{iter_0#99 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- c_1_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#100))))*{iter_0#100 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#14)))))}*{c_1#14 <- c_1_lst} + def $fvunop_{v_M : nat, def $f_(v_N : N, v_fN : fN) : fN*, v_1 : uN}(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), c_lst_4)*{c_lst_4 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_51))*{iter_0_51 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_13)))))}*{c_1_13 <- c_1_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_52))))*{iter_0_52 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_14)))))}*{c_1_14 <- c_1_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinop_(v_shape : shape, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_vec_ : vec_, v_vec__0 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#21)*{c#21 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#16)), !($proj_lane__2(c_2#2)))*{c_1#16 <- c_1_lst, c_2#2 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#20)))*{c#20 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#24)*{c#24 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#18)), !($proj_lane__2(c_2#4)))*{c_1#18 <- c_1_lst, c_2#4 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#23)))*{c#23 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#27)*{c#27 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#20)), !($proj_lane__2(c_2#6)))*{c_1#20 <- c_1_lst, c_2#6 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#26)))*{c#26 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#30)*{c#30 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#22)), !($proj_lane__2(c_2#8)))*{c_1#22 <- c_1_lst, c_2#8 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#29)))*{c#29 <- c_lst} + def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_16)*{c_16 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_16)), !($proj_lane__2(c_2_2)))*{c_1_16 <- c_1_lst, c_2_2 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_18)*{c_18 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_18)), !($proj_lane__2(c_2_4)))*{c_1_18 <- c_1_lst, c_2_4 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_20)*{c_20 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_20)), !($proj_lane__2(c_2_6)))*{c_1_20 <- c_1_lst, c_2_6 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_22)*{c_22 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_22)), !($proj_lane__2(c_2_8)))*{c_1_22 <- c_1_lst, c_2_8 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsx_(v_shape : shape, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_vec_ : vec_, v_vec__0 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#33)*{c#33 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#10)))*{c_1#24 <- c_1_lst, c_2#10 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#32)))*{c#32 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#36)*{c#36 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#26)), !($proj_lane__2(c_2#12)))*{c_1#26 <- c_1_lst, c_2#12 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#35)))*{c#35 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#39)*{c#39 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#28)), !($proj_lane__2(c_2#14)))*{c_1#28 <- c_1_lst, c_2#14 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#38)))*{c#38 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#42)*{c#42 <- c_lst})] - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#16)))*{c_1#30 <- c_1_lst, c_2#16 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#41)))*{c#41 <- c_lst} + def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_24)*{c_24 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_24)), !($proj_lane__2(c_2_10)))*{c_1_24 <- c_1_lst, c_2_10 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_26)*{c_26 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_26)), !($proj_lane__2(c_2_12)))*{c_1_26 <- c_1_lst, c_2_12 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_28)*{c_28 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_28)), !($proj_lane__2(c_2_14)))*{c_1_28 <- c_1_lst, c_2_14 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = [$inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_30)*{c_30 <- c_lst})] + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_30)), !($proj_lane__2(c_2_16)))*{c_1_30 <- c_1_lst, c_2_16 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivbinopsxnd_(v_shape : shape, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_vec_ : vec_, v_vec__0 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), c_lst#6)*{c_lst#6 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#101)*{iter_0#101 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#32)), !($proj_lane__2(c_2#18)))}*{c_1#32 <- c_1_lst, c_2#18 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#102)))*{iter_0#102 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#19)))}*{c_1#33 <- c_1_lst, c_2#19 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), c_lst#8)*{c_lst#8 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#103)*{iter_0#103 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#35)), !($proj_lane__2(c_2#21)))}*{c_1#35 <- c_1_lst, c_2#21 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#104)))*{iter_0#104 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#22)))}*{c_1#36 <- c_1_lst, c_2#22 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), c_lst#10)*{c_lst#10 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#105)*{iter_0#105 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#38)), !($proj_lane__2(c_2#24)))}*{c_1#38 <- c_1_lst, c_2#24 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#106)))*{iter_0#106 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#25)))}*{c_1#39 <- c_1_lst, c_2#25 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), c_lst#12)*{c_lst#12 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#107)*{iter_0#107 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#41)), !($proj_lane__2(c_2#27)))}*{c_1#41 <- c_1_lst, c_2#27 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#108)))*{iter_0#108 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#28)))}*{c_1#42 <- c_1_lst, c_2#28 <- c_2_lst} + def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), c_lst_6)*{c_lst_6 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0_53)*{iter_0_53 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_32)), !($proj_lane__2(c_2_18)))}*{c_1_32 <- c_1_lst, c_2_18 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0_54)))*{iter_0_54 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_33)), !($proj_lane__2(c_2_19)))}*{c_1_33 <- c_1_lst, c_2_19 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), c_lst_8)*{c_lst_8 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0_55)*{iter_0_55 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_35)), !($proj_lane__2(c_2_21)))}*{c_1_35 <- c_1_lst, c_2_21 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0_56)))*{iter_0_56 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_36)), !($proj_lane__2(c_2_22)))}*{c_1_36 <- c_1_lst, c_2_22 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), c_lst_10)*{c_lst_10 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0_57)*{iter_0_57 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_38)), !($proj_lane__2(c_2_24)))}*{c_1_38 <- c_1_lst, c_2_24 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0_58)))*{iter_0_58 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_39)), !($proj_lane__2(c_2_25)))}*{c_1_39 <- c_1_lst, c_2_25 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivbinopsxnd_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : iN*, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), c_lst_12)*{c_lst_12 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0_59)*{iter_0_59 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_41)), !($proj_lane__2(c_2_27)))}*{c_1_41 <- c_1_lst, c_2_27 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0_60)))*{iter_0_60 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_42)), !($proj_lane__2(c_2_28)))}*{c_1_42 <- c_1_lst, c_2_28 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvbinop_(v_shape : shape, def $f_(v_N : N, v_fN : fN, v_fN : fN) : fN*, v_vec_ : vec_, v_vec__0 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), c_lst#14)*{c_lst#14 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#109))*{iter_0#109 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#44)))), !($proj_num__1(!($proj_lane__0(c_2#30)))))}*{c_1#44 <- c_1_lst, c_2#30 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#110))))*{iter_0#110 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#45)))), !($proj_num__1(!($proj_lane__0(c_2#31)))))}*{c_1#45 <- c_1_lst, c_2#31 <- c_2_lst} + def $fvbinop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), c_lst_14)*{c_lst_14 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_61))*{iter_0_61 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_44)))), !($proj_num__1(!($proj_lane__0(c_2_30)))))}*{c_1_44 <- c_1_lst, c_2_30 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_62))))*{iter_0_62 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_45)))), !($proj_num__1(!($proj_lane__0(c_2_31)))))}*{c_1_45 <- c_1_lst, c_2_31 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvbinop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), c_lst#16)*{c_lst#16 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_2) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#111))*{iter_0#111 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#47)))), !($proj_num__1(!($proj_lane__0(c_2#33)))))}*{c_1#47 <- c_1_lst, c_2#33 <- c_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#112))))*{iter_0#112 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#48)))), !($proj_num__1(!($proj_lane__0(c_2#34)))))}*{c_1#48 <- c_1_lst, c_2#34 <- c_2_lst} + def $fvbinop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), c_lst_16)*{c_lst_16 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_63))*{iter_0_63 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_47)))), !($proj_num__1(!($proj_lane__0(c_2_33)))))}*{c_1_47 <- c_1_lst, c_2_33 <- c_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_64))))*{iter_0_64 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_48)))), !($proj_num__1(!($proj_lane__0(c_2_34)))))}*{c_1_48 <- c_1_lst, c_2_34 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivternopnd_(v_shape : shape, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_vec_ : vec_, v_vec__0 : vec_, v_vec__1 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), c_lst#18)*{c_lst#18 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#113)*{iter_0#113 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#50)), !($proj_lane__2(c_2#36)), !($proj_lane__2(c_3#2)))}*{c_1#50 <- c_1_lst, c_2#36 <- c_2_lst, c_3#2 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#114)))*{iter_0#114 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#37)), !($proj_lane__2(c_3#3)))}*{c_1#51 <- c_1_lst, c_2#37 <- c_2_lst, c_3#3 <- c_3_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), c_lst#20)*{c_lst#20 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#115)*{iter_0#115 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#53)), !($proj_lane__2(c_2#39)), !($proj_lane__2(c_3#5)))}*{c_1#53 <- c_1_lst, c_2#39 <- c_2_lst, c_3#5 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#116)))*{iter_0#116 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#40)), !($proj_lane__2(c_3#6)))}*{c_1#54 <- c_1_lst, c_2#40 <- c_2_lst, c_3#6 <- c_3_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), c_lst#22)*{c_lst#22 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#117)*{iter_0#117 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#56)), !($proj_lane__2(c_2#42)), !($proj_lane__2(c_3#8)))}*{c_1#56 <- c_1_lst, c_2#42 <- c_2_lst, c_3#8 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#118)))*{iter_0#118 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#57)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#9)))}*{c_1#57 <- c_1_lst, c_2#43 <- c_2_lst, c_3#9 <- c_3_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), c_lst#24)*{c_lst#24 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#119)*{iter_0#119 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#59)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#11)))}*{c_1#59 <- c_1_lst, c_2#45 <- c_2_lst, c_3#11 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#120)))*{iter_0#120 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#60)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#12)))}*{c_1#60 <- c_1_lst, c_2#46 <- c_2_lst, c_3#12 <- c_3_lst} + def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), c_lst_18)*{c_lst_18 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0_65)*{iter_0_65 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_50)), !($proj_lane__2(c_2_36)), !($proj_lane__2(c_3_2)))}*{c_1_50 <- c_1_lst, c_2_36 <- c_2_lst, c_3_2 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0_66)))*{iter_0_66 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_51)), !($proj_lane__2(c_2_37)), !($proj_lane__2(c_3_3)))}*{c_1_51 <- c_1_lst, c_2_37 <- c_2_lst, c_3_3 <- c_3_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), c_lst_20)*{c_lst_20 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0_67)*{iter_0_67 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_53)), !($proj_lane__2(c_2_39)), !($proj_lane__2(c_3_5)))}*{c_1_53 <- c_1_lst, c_2_39 <- c_2_lst, c_3_5 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0_68)))*{iter_0_68 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_54)), !($proj_lane__2(c_2_40)), !($proj_lane__2(c_3_6)))}*{c_1_54 <- c_1_lst, c_2_40 <- c_2_lst, c_3_6 <- c_3_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), c_lst_22)*{c_lst_22 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0_69)*{iter_0_69 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_56)), !($proj_lane__2(c_2_42)), !($proj_lane__2(c_3_8)))}*{c_1_56 <- c_1_lst, c_2_42 <- c_2_lst, c_3_8 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0_70)))*{iter_0_70 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_57)), !($proj_lane__2(c_2_43)), !($proj_lane__2(c_3_9)))}*{c_1_57 <- c_1_lst, c_2_43 <- c_2_lst, c_3_9 <- c_3_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivternopnd_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN, v_iN : iN) : iN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), c_lst_24)*{c_lst_24 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0_71)*{iter_0_71 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_59)), !($proj_lane__2(c_2_45)), !($proj_lane__2(c_3_11)))}*{c_1_59 <- c_1_lst, c_2_45 <- c_2_lst, c_3_11 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0_72)))*{iter_0_72 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_60)), !($proj_lane__2(c_2_46)), !($proj_lane__2(c_3_12)))}*{c_1_60 <- c_1_lst, c_2_46 <- c_2_lst, c_3_12 <- c_3_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvternop_(v_shape : shape, def $f_(v_N : N, v_fN : fN, v_fN : fN, v_fN : fN) : fN*, v_vec_ : vec_, v_vec__0 : vec_, v_vec__1 : vec_) : vec_* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), c_lst#26)*{c_lst#26 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#121))*{iter_0#121 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#62)))), !($proj_num__1(!($proj_lane__0(c_2#48)))), !($proj_num__1(!($proj_lane__0(c_3#14)))))}*{c_1#62 <- c_1_lst, c_2#48 <- c_2_lst, c_3#14 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0#122))))*{iter_0#122 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#63)))), !($proj_num__1(!($proj_lane__0(c_2#49)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#63 <- c_1_lst, c_2#49 <- c_2_lst, c_3#15 <- c_3_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvternop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), c_lst#28)*{c_lst#28 <- c_lst_lst} - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_2) - -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_3) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#123))*{iter_0#123 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#65)))), !($proj_num__1(!($proj_lane__0(c_2#51)))), !($proj_num__1(!($proj_lane__0(c_3#17)))))}*{c_1#65 <- c_1_lst, c_2#51 <- c_2_lst, c_3#17 <- c_3_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0#124))))*{iter_0#124 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#66)))), !($proj_num__1(!($proj_lane__0(c_2#52)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#66 <- c_1_lst, c_2#52 <- c_2_lst, c_3#18 <- c_3_lst} + def $fvternop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), c_lst_26)*{c_lst_26 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_73))*{iter_0_73 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_62)))), !($proj_num__1(!($proj_lane__0(c_2_48)))), !($proj_num__1(!($proj_lane__0(c_3_14)))))}*{c_1_62 <- c_1_lst, c_2_48 <- c_2_lst, c_3_14 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, iter_0_74))))*{iter_0_74 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_63)))), !($proj_num__1(!($proj_lane__0(c_2_49)))), !($proj_num__1(!($proj_lane__0(c_3_15)))))}*{c_1_63 <- c_1_lst, c_2_49 <- c_2_lst, c_3_15 <- c_3_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvternop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN, v_fN : fN) : fN*, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2, v_3) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), c_lst_28)*{c_lst_28 <- c_lst_lst} + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_3_lst : lane_*} c_3_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_3) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_75))*{iter_0_75 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_65)))), !($proj_num__1(!($proj_lane__0(c_2_51)))), !($proj_num__1(!($proj_lane__0(c_3_17)))))}*{c_1_65 <- c_1_lst, c_2_51 <- c_2_lst, c_3_17 <- c_3_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M))) + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, iter_0_76))))*{iter_0_76 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_66)))), !($proj_num__1(!($proj_lane__0(c_2_52)))), !($proj_num__1(!($proj_lane__0(c_3_18)))))}*{c_1_66 <- c_1_lst, c_2_52 <- c_2_lst, c_3_18 <- c_3_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelop_(v_shape : shape, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_vec_ : vec_, v_vec__0 : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#69)*{c#69 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#68)), !($proj_lane__2(c_2#54)))).0))*{c_1#68 <- c_1_lst, c_2#54 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#68)))*{c#68 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#55)))).0)))*{c_1#69 <- c_1_lst, c_2#55 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#72)*{c#72 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#71)), !($proj_lane__2(c_2#57)))).0))*{c_1#71 <- c_1_lst, c_2#57 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#71)))*{c#71 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#58)))).0)))*{c_1#72 <- c_1_lst, c_2#58 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#75)*{c#75 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#74)), !($proj_lane__2(c_2#60)))).0))*{c_1#74 <- c_1_lst, c_2#60 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#74)))*{c#74 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#75)), !($proj_lane__2(c_2#61)))).0)))*{c_1#75 <- c_1_lst, c_2#61 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#78)*{c#78 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#77)), !($proj_lane__2(c_2#63)))).0))*{c_1#77 <- c_1_lst, c_2#63 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#77)))*{c#77 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#78)), !($proj_lane__2(c_2#64)))).0)))*{c_1#78 <- c_1_lst, c_2#64 <- c_2_lst} + def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_56)*{c_56 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_68)), !($proj_lane__2(c_2_54)))).0))*{c_1_68 <- c_1_lst, c_2_54 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_69)), !($proj_lane__2(c_2_55)))).0)))*{c_1_69 <- c_1_lst, c_2_55 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_58)*{c_58 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_71)), !($proj_lane__2(c_2_57)))).0))*{c_1_71 <- c_1_lst, c_2_57 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_72)), !($proj_lane__2(c_2_58)))).0)))*{c_1_72 <- c_1_lst, c_2_58 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_60)*{c_60 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_74)), !($proj_lane__2(c_2_60)))).0))*{c_1_74 <- c_1_lst, c_2_60 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_75)), !($proj_lane__2(c_2_61)))).0)))*{c_1_75 <- c_1_lst, c_2_61 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_iN : iN) : u32, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_62)*{c_62 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_77)), !($proj_lane__2(c_2_63)))).0))*{c_1_77 <- c_1_lst, c_2_63 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_78)), !($proj_lane__2(c_2_64)))).0)))*{c_1_78 <- c_1_lst, c_2_64 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivrelopsx_(v_shape : shape, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_vec_ : vec_, v_vec__0 : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#81)*{c#81 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#80)), !($proj_lane__2(c_2#66)))).0))*{c_1#80 <- c_1_lst, c_2#66 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#80)))*{c#80 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#81)), !($proj_lane__2(c_2#67)))).0)))*{c_1#81 <- c_1_lst, c_2#67 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#84)*{c#84 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#83)), !($proj_lane__2(c_2#69)))).0))*{c_1#83 <- c_1_lst, c_2#69 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#83)))*{c#83 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#84)), !($proj_lane__2(c_2#70)))).0)))*{c_1#84 <- c_1_lst, c_2#70 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#87)*{c#87 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#86)), !($proj_lane__2(c_2#72)))).0))*{c_1#86 <- c_1_lst, c_2#72 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#86)))*{c#86 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#87)), !($proj_lane__2(c_2#73)))).0)))*{c_1#87 <- c_1_lst, c_2#73 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#90)*{c#90 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, `%`_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#89)), !($proj_lane__2(c_2#75)))).0))*{c_1#89 <- c_1_lst, c_2#75 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#89)))*{c#89 <- c_lst} - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#90)), !($proj_lane__2(c_2#76)))).0)))*{c_1#90 <- c_1_lst, c_2#76 <- c_2_lst} + def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_64)*{c_64 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_80)), !($proj_lane__2(c_2_66)))).0))*{c_1_80 <- c_1_lst, c_2_66 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_81)), !($proj_lane__2(c_2_67)))).0)))*{c_1_81 <- c_1_lst, c_2_67 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_66)*{c_66 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_83)), !($proj_lane__2(c_2_69)))).0))*{c_1_83 <- c_1_lst, c_2_69 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_84)), !($proj_lane__2(c_2_70)))).0)))*{c_1_84 <- c_1_lst, c_2_70 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_68)*{c_68 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_86)), !($proj_lane__2(c_2_72)))).0))*{c_1_86 <- c_1_lst, c_2_72 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_87)), !($proj_lane__2(c_2_73)))).0)))*{c_1_87 <- c_1_lst, c_2_73 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivrelopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_iN : iN) : u32, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_70)*{c_70 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, mk_uN_iN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_89)), !($proj_lane__2(c_2_75)))).0))*{c_1_89 <- c_1_lst, c_2_75 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_90)), !($proj_lane__2(c_2_76)))).0)))*{c_1_90 <- c_1_lst, c_2_76 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fvrelop_(v_shape : shape, def $f_(v_N : N, v_fN : fN, v_fN : fN) : u32, v_vec_ : vec_, v_vec__0 : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : u32, v_1 : uN, v_2 : uN, v_Inn : addrtype}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M)), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, `%`_uN($proj_uN_0(c#93).0)))*{c#93 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#92)))), !($proj_num__1(!($proj_lane__0(c_2#78)))))).0))*{c_1#92 <- c_1_lst, c_2#78 <- c_2_lst} + def $fvrelop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : u32, v_1 : uN, v_2 : uN, v_Inn : addrtype}(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(v_Inn), mk_dim_dim(v_M)), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, mk_uN_uN($proj_uN_0(c_72).0)))*{c_72 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $sizenn($numtype_Fnn(F32_Fnn)), S_sx, mk_uN_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_92)))), !($proj_num__1(!($proj_lane__0(c_2_78)))))).0))*{c_1_92 <- c_1_lst, c_2_78 <- c_2_lst} -- if ($isize(v_Inn) = $fsize(F32_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M))), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, `%`_uN($proj_uN_0(c#92).0)))))*{c#92 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#93)))), !($proj_num__1(!($proj_lane__0(c_2#79)))))).0)))*{c_1#93 <- c_1_lst, c_2#79 <- c_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fvrelop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : u32, v_1 : uN, v_2 : uN, v_Inn : addrtype}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M)), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, `%`_uN($proj_uN_0(c#96).0)))*{c#96 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, `%`_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#95)))), !($proj_num__1(!($proj_lane__0(c_2#81)))))).0))*{c_1#95 <- c_1_lst, c_2#81 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_93)))), !($proj_num__1(!($proj_lane__0(c_2_79)))))).0)))*{c_1_93 <- c_1_lst, c_2_79 <- c_2_lst} + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $fvrelop_{v_M : nat, def $f_(v_N : N, v_fN : fN, v_fN : fN) : u32, v_1 : uN, v_2 : uN, v_Inn : addrtype}(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_addrtype(v_Inn), mk_dim_dim(v_M)), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, mk_uN_uN($proj_uN_0(c_74).0)))*{c_74 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $extend__(1, $sizenn($numtype_Fnn(F64_Fnn)), S_sx, mk_uN_iN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_95)))), !($proj_num__1(!($proj_lane__0(c_2_81)))))).0))*{c_1_95 <- c_1_lst, c_2_81 <- c_2_lst} -- if ($isize(v_Inn) = $fsize(F64_Fnn)) - -- wf_shape: `%`(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(v_Inn), `%`_dim(v_M))), mk_lane__0_lane_($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, `%`_uN($proj_uN_0(c#95).0)))))*{c#95 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) - -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#96)))), !($proj_num__1(!($proj_lane__0(c_2#82)))))).0)))*{c_1#96 <- c_1_lst, c_2#82 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M))) + -- (wf_uN: `%%`(1, mk_uN_uN($proj_uN_0($f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1_96)))), !($proj_num__1(!($proj_lane__0(c_2_82)))))).0)))*{c_1_96 <- c_1_lst, c_2_82 <- c_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftop_(v_shape : shape, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_vec_ : vec_, v_u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#99)*{c#99 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#98)), i)*{c_1#98 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#98)))*{c#98 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#102)*{c#102 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#100)), i)*{c_1#100 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#101)))*{c#101 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#105)*{c#105 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#102)), i)*{c_1#102 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#104)))*{c#104 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#108)*{c#108 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#104)), i)*{c_1#104 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#107)))*{c#107 <- c_lst} + def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_76)*{c_76 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_98)), i)*{c_1_98 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_78)*{c_78 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_100)), i)*{c_1_100 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_80)*{c_80 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_102)), i)*{c_1_102 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftop_{v_M : nat, def $f_(v_N : N, v_iN : iN, v_u32 : u32) : iN, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_82)*{c_82 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_104)), i)*{c_1_104 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivshiftopsx_(v_shape : shape, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_vec_ : vec_, v_u32 : u32) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#111)*{c#111 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#106)), i)*{c_1#106 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#110)))*{c#110 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#114)*{c#114 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#108)), i)*{c_1#108 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#113)))*{c#113 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#117)*{c#117 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#110)), i)*{c_1#110 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#116)))*{c#116 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#120)*{c#120 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#112)), i)*{c_1#112 <- c_1_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#119)))*{c#119 <- c_lst} + def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_84)*{c_84 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_106)), i)*{c_1_106 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_86)*{c_86 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_108)), i)*{c_1_108 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_88)*{c_88 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_110)), i)*{c_1_110 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivshiftopsx_{v_M : nat, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 : u32) : iN, v_sx : sx, v_1 : uN, i : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_sx, v_1, i) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_90)*{c_90 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_112)), i)*{c_1_112 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(v_shape : shape, v_vec_ : vec_) : u32 - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#114)), `%`_iN(0))).0)*{c_1#114 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#115)), `%`_iN(0))).0)))*{c_1#115 <- c_1_lst} - -- wf_bit: `%`(`%`_bit(0)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#117)), `%`_iN(0))).0)*{c_1#117 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#118)), `%`_iN(0))).0)))*{c_1#118 <- c_1_lst} - -- wf_bit: `%`(`%`_bit(0)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#120)), `%`_iN(0))).0)*{c_1#120 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#121)), `%`_iN(0))).0)))*{c_1#121 <- c_1_lst} - -- wf_bit: `%`(`%`_bit(0)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#123)), `%`_iN(0))).0)*{c_1#123 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) - -- wf_uN: `%%`(32, c) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#124)), `%`_iN(0))).0)))*{c_1#124 <- c_1_lst} - -- wf_bit: `%`(`%`_bit(0)) +relation fun_ivbitmaskop_: `%%%`(shape, vec_, u32) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_0{v_M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), v_1, $irev_(32, c)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- if ($ibits_(32, c) = mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1_114)), mk_uN_iN(0))).0)*{c_1_114 <- c_1_lst} ++ mk_bit_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1_114) =/= ?()))*{c_1_114 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + -- (wf_bit: `%`(mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1_115)), mk_uN_iN(0))).0)))*{c_1_115 <- c_1_lst} + -- (if ($proj_lane__2(c_1_115) =/= ?()))*{c_1_115 <- c_1_lst} + -- wf_bit: `%`(mk_bit_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_1{v_M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), v_1, $irev_(32, c)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- if ($ibits_(32, c) = mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1_117)), mk_uN_iN(0))).0)*{c_1_117 <- c_1_lst} ++ mk_bit_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1_117) =/= ?()))*{c_1_117 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + -- (wf_bit: `%`(mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1_118)), mk_uN_iN(0))).0)))*{c_1_118 <- c_1_lst} + -- (if ($proj_lane__2(c_1_118) =/= ?()))*{c_1_118 <- c_1_lst} + -- wf_bit: `%`(mk_bit_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_2{v_M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), v_1, $irev_(32, c)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- if ($ibits_(32, c) = mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1_120)), mk_uN_iN(0))).0)*{c_1_120 <- c_1_lst} ++ mk_bit_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1_120) =/= ?()))*{c_1_120 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + -- (wf_bit: `%`(mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1_121)), mk_uN_iN(0))).0)))*{c_1_121 <- c_1_lst} + -- (if ($proj_lane__2(c_1_121) =/= ?()))*{c_1_121 <- c_1_lst} + -- wf_bit: `%`(mk_bit_bit(0)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_3{v_M : nat, v_1 : uN, c : uN}: + `%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), v_1, $irev_(32, c)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- if ($ibits_(32, c) = mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1_123)), mk_uN_iN(0))).0)*{c_1_123 <- c_1_lst} ++ mk_bit_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + -- (if ($proj_lane__2(c_1_123) =/= ?()))*{c_1_123 <- c_1_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) + -- (wf_bit: `%`(mk_bit_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1_124)), mk_uN_iN(0))).0)))*{c_1_124 <- c_1_lst} + -- (if ($proj_lane__2(c_1_124) =/= ?()))*{c_1_124 <- c_1_lst} + -- wf_bit: `%`(mk_bit_bit(0)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivswizzlop_(v_shape : shape, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_vec_ : vec_, v_vec__0 : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c#123)*{c#123 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#126))*{c_1#126 <- c_1_lst}, !($proj_lane__2(c_2#84)))*{c_2#84 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I32_Jnn, c#122)))*{c#122 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c#126)*{c#126 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#128))*{c_1#128 <- c_1_lst}, !($proj_lane__2(c_2#86)))*{c_2#86 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I64_Jnn, c#125)))*{c#125 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c#129)*{c#129 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#130))*{c_1#130 <- c_1_lst}, !($proj_lane__2(c_2#88)))*{c_2#88 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I8_Jnn, c#128)))*{c#128 <- c_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c#132)*{c#132 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#132))*{c_1#132 <- c_1_lst}, !($proj_lane__2(c_2#90)))*{c_2#90 <- c_2_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(I16_Jnn, c#131)))*{c#131 <- c_lst} + def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I32_Jnn, c_92)*{c_92 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1_126))*{c_1_126 <- c_1_lst}, !($proj_lane__2(c_2_84)))*{c_2_84 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I64_Jnn, c_94)*{c_94 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1_128))*{c_1_128 <- c_1_lst}, !($proj_lane__2(c_2_86)))*{c_2_86 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I8_Jnn, c_96)*{c_96 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1_130))*{c_1_130 <- c_1_lst}, !($proj_lane__2(c_2_88)))*{c_2_88 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivswizzlop_{v_M : nat, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(I16_Jnn, c_98)*{c_98 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : iN*} c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1_132))*{c_1_132 <- c_1_lst}, !($proj_lane__2(c_2_90)))*{c_2_90 <- c_2_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivshufflop_(v_shape : shape, var_0 : laneidx*, v_vec_ : vec_, v_vec__0 : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), c_lst) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#139142).0]*{i#139142 <- i_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), c_lst) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#139149).0]*{i#139149 <- i_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), c_lst) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#139156).0]*{i#139156 <- i_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), c_lst) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2) - -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#139163).0]*{i#139163 <- i_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) +relation fun_ivshufflop_: `%%%%%`(shape, laneidx*, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_0{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), i_lst, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), c_lst)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i_139043).0]*{i_139043 <- i_lst} + -- (if ($proj_uN_0(i_139043).0 < |c_1_lst ++ c_2_lst|))*{i_139043 <- i_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_1{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), i_lst, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), c_lst)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i_139050).0]*{i_139050 <- i_lst} + -- (if ($proj_uN_0(i_139050).0 < |c_1_lst ++ c_2_lst|))*{i_139050 <- i_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_2{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), i_lst, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), c_lst)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i_139057).0]*{i_139057 <- i_lst} + -- (if ($proj_uN_0(i_139057).0 < |c_1_lst ++ c_2_lst|))*{i_139057 <- i_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_3{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), i_lst, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), c_lst)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v_2) + -- let{c_lst : lane_*} c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i_139064).0]*{i_139064 <- i_lst} + -- (if ($proj_uN_0(i_139064).0 < |c_1_lst ++ c_2_lst|))*{i_139064 <- i_lst} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $vvunop_(v_vectype : vectype, v_vvunop : vvunop, v_vec_ : vec_) : vec_* @@ -9537,1887 +12406,2547 @@ def $vvternop_(v_vectype : vectype, v_vvternop : vvternop, v_vec_ : vec_, v_vec_ def $vvternop_{v_Vnn : vectype, v_1 : uN, v_2 : uN, v_3 : uN}(v_Vnn, BITSELECT_vvternop, v_1, v_2, v_3) = [$ibitselect_($vsizenn(v_Vnn), v_1, v_2, v_3)] ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vunop_(v_shape : shape, v_vunop_ : vunop_, v_vec_ : vec_) : vec_* +relation fun_vunop_: `%%%%`(shape, vunop_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_0{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, ABS_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_1{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, ABS_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_2{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fneg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, NEG_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fneg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_3{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEG_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fneg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_4{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fsqrt_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, SQRT_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fsqrt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_5{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, SQRT_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fsqrt_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_6{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fceil_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, CEIL_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fceil_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_7{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, CEIL_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fceil_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_8{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $ffloor_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, FLOOR_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $ffloor_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_9{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, FLOOR_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $ffloor_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_10{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $ftrunc_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, TRUNC_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $ftrunc_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_11{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, TRUNC_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $ftrunc_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, v_M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_12{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F32_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fnearest_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, v_M, NEAREST_vunop_Fnn_M), v) = $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fnearest_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vunop__case_13{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vunop__1_vunop_(F64_Fnn, M_0, NEAREST_vunop_Fnn_M), v, $fvunop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fnearest_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, v_M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_14{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $iabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, v_M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_15{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $iabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, v_M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_16{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $iabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, v_M, ABS_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $iabs_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_17{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, M_0, ABS_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $iabs_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, v_M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_18{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ineg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, v_M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_19{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ineg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, v_M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_20{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ineg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, v_M, NEG_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ineg_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_21{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, M_0, NEG_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ineg_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, v_M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_22{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I32_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ipopcnt_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, v_M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_23{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I64_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ipopcnt_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, v_M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_24{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I8_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ipopcnt_, v)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vunop_{v_M : nat, v : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, v_M, POPCNT_vunop_Jnn_M), v) = $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ipopcnt_, v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vunop__case_25{v_M : nat, v : uN, M_0 : nat}: + `%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vunop__0_vunop_(I16_Jnn, M_0, POPCNT_vunop_Jnn_M), v, $ivunop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ipopcnt_, v)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vbinop_(v_shape : shape, v_vbinop_ : vbinop_, v_vec_ : vec_, v_vec__0 : vec_) : vec_* +relation fun_vbinop_: `%%%%%`(shape, vbinop_, vec_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_0{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $iadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_1{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $iadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_2{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $iadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, ADD_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $iadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_3{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $iadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_4{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $isub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_5{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $isub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_6{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $isub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, SUB_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $isub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_7{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $isub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_8{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $imul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_9{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $imul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_10{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $imul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, MUL_vbinop_Jnn_M), v_1, v_2) = $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $imul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_11{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MUL_vbinop_Jnn_M), v_1, v_2, $ivbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $imul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_12{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_13{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_14{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_15{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, ADD_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $iadd_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_16{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_17{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_18{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_19{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, SUB_SAT_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $isub_sat_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $imin_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_20{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $imin_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $imin_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_21{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $imin_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $imin_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_22{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $imin_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $imin_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_23{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MIN_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $imin_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $imax_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_24{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $imax_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $imax_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_25{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $imax_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $imax_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_26{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $imax_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $imax_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_27{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, MAX_vbinop_Jnn_M(v_sx)), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $imax_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_28{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_29{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_30{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, AVGRU_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $iavgr_, U_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_31{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, AVGRU_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $iavgr_, U_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_32{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_33{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_34{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_35{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, Q15MULR_SATS_vbinop_Jnn_M), v_1, v_2, $ivbinopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $iq15mulr_sat_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, v_M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_36{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I32_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, v_M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_37{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I64_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, v_M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_38{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I8_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, v_M, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2) = $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbinop__case_39{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vbinop__0_vbinop_(I16_Jnn, M_0, RELAXED_Q15MULRS_vbinop_Jnn_M), v_1, v_2, $ivbinopsxnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $irelaxed_q15mulr_, S_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_40{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, ADD_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fadd_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_41{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, ADD_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fadd_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_42{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fsub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, SUB_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fsub_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_43{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, SUB_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fsub_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_44{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fmul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, MUL_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fmul_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_45{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MUL_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fmul_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_46{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fdiv_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, DIV_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fdiv_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_47{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, DIV_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fdiv_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_48{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fmin_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_49{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fmin_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_50{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fmax_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_51{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fmax_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_52{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fpmin_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, PMIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fpmin_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_53{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fpmin_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_54{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fpmax_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, PMAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fpmax_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_55{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, PMAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fpmax_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_56{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $frelaxed_min_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $frelaxed_min_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_57{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MIN_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $frelaxed_min_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, v_M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_58{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F32_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $frelaxed_max_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vbinop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, v_M, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2) = $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $frelaxed_max_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vbinop__case_59{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vbinop__1_vbinop_(F64_Fnn, M_0, RELAXED_MAX_vbinop_Fnn_M), v_1, v_2, $fvbinop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $frelaxed_max_, v_1, v_2)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vternop_(v_shape : shape, v_vternop_ : vternop_, v_vec_ : vec_, v_vec__0 : vec_, v_vec__1 : vec_) : vec_* +relation fun_vternop_: `%%%%%%`(shape, vternop_, vec_, vec_, vec_, vec_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vternop__0_vternop_(I32_Jnn, v_M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vternop__case_0{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vternop__0_vternop_(I32_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vternop__0_vternop_(I64_Jnn, v_M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vternop__case_1{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vternop__0_vternop_(I64_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vternop__0_vternop_(I8_Jnn, v_M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vternop__case_2{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vternop__0_vternop_(I8_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vternop__0_vternop_(I16_Jnn, v_M, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3) = $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vternop__case_3{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vternop__0_vternop_(I16_Jnn, M_0, RELAXED_LANESELECT_vternop_Jnn_M), v_1, v_2, v_3, $ivternopnd_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $irelaxed_laneselect_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vternop__1_vternop_(F32_Fnn, v_M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vternop__case_4{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vternop__1_vternop_(F64_Fnn, v_M, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $frelaxed_madd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vternop__case_5{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_MADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $frelaxed_madd_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vternop__1_vternop_(F32_Fnn, v_M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vternop__case_6{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vternop__1_vternop_(F32_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vternop_{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vternop__1_vternop_(F64_Fnn, v_M, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3) = $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $frelaxed_nmadd_, v_1, v_2, v_3) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vternop__case_7{v_M : nat, v_1 : uN, v_2 : uN, v_3 : uN, M_0 : nat}: + `%%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vternop__1_vternop_(F64_Fnn, M_0, RELAXED_NMADD_vternop_Fnn_M), v_1, v_2, v_3, $fvternop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $frelaxed_nmadd_, v_1, v_2, v_3)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vrelop_(v_shape : shape, v_vrelop_ : vrelop_, v_vec_ : vec_, v_vec__0 : vec_) : vec_ +relation fun_vrelop_: `%%%%%`(shape, vrelop_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_0{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ieq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_1{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ieq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_2{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ieq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, EQ_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ieq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_3{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, EQ_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ieq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_4{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ine_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_5{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ine_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_6{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ine_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, NE_vrelop_Jnn_M), v_1, v_2) = $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ine_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_7{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, NE_vrelop_Jnn_M), v_1, v_2, $ivrelop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ine_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, LT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ilt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_8{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ilt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, LT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ilt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_9{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ilt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, LT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ilt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_10{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ilt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, LT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ilt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_11{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ilt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, GT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $igt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_12{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $igt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, GT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $igt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_13{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $igt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, GT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $igt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_14{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $igt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, GT_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $igt_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_15{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GT_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $igt_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, LE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ile_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_16{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, LE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ile_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, LE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ile_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_17{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, LE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ile_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, LE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ile_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_18{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, LE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ile_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, LE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ile_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_19{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, LE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ile_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, v_M, GE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ige_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_20{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I32_Jnn, M_0, GE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ige_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, v_M, GE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ige_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_21{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I64_Jnn, M_0, GE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ige_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, v_M, GE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ige_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_22{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I8_Jnn, M_0, GE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ige_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, v_M, GE_vrelop_Jnn_M(v_sx)), v_1, v_2) = $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ige_, v_sx, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vrelop__case_23{v_M : nat, v_sx : sx, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M)), mk_vrelop__0_vrelop_(I16_Jnn, M_0, GE_vrelop_Jnn_M(v_sx)), v_1, v_2, $ivrelopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ige_, v_sx, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_24{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $feq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, EQ_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $feq_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_25{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, EQ_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $feq_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_26{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fne_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, NE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fne_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_27{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, NE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fne_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_28{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $flt_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, LT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $flt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_29{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $flt_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_30{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fgt_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, GT_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fgt_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_31{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GT_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fgt_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_32{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fle_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, LE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fle_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_33{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, LE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fle_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F32_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, v_M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_34{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F32_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F32_Fnn), mk_dim_dim(v_M)), def $fge_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vrelop_{v_M : nat, v_1 : uN, v_2 : uN}(`%X%`_shape(F64_lanetype, `%`_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, v_M, GE_vrelop_Fnn_M), v_1, v_2) = $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M)), def $fge_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(v_M))) + rule fun_vrelop__case_35{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(v_M)), mk_vrelop__1_vrelop_(F64_Fnn, M_0, GE_vrelop_Fnn_M), v_1, v_2, $fvrelop_(`%X%`_shape($lanetype_Fnn(F64_Fnn), mk_dim_dim(v_M)), def $fge_, v_1, v_2)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $lcvtop__(shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__, v_lane_ : lane_) : lane_* +relation fun_lcvtop__: `%%%%%`(shape, shape, vcvtop__, lane_, lane_*) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_0{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_1{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_2{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I32_Jnn, c)] + rule fun_lcvtop___case_3{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I32_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_4{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_5{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_6{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I64_Jnn, c)] + rule fun_lcvtop___case_7{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I64_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_8{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_9{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_10{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I8_Jnn, c)] + rule fun_lcvtop___case_11{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I8_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_12{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_13{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_14{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__2_lane_(I16_Jnn, c)] + rule fun_lcvtop___case_15{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), mk_vcvtop___0_vcvtop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__2_lane_(I16_Jnn, c)]) -- let{c : iN} c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_16{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_17{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_18{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F32_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))] + rule fun_lcvtop___case_19{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F32_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_20{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I32_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I32_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_21{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I64_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I64_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_22{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I8_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I8_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1, F64_Fnn, M_2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1)) = [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))] + rule fun_lcvtop___case_23{M_1 : nat, M_2 : nat, half_opt : half?, v_sx : sx, c_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___1_vcvtop__(I16_Jnn, M_1_0, F64_Fnn, M_2_0, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(half_opt, v_sx)), mk_lane__2_lane_(I16_Jnn, c_1), [mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))]) -- let{c : fN} c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c))) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#143))?{c#143 <- c_opt}) + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_108))?{c_108 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#142))))?{c#142 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#146))?{c#146 <- c_opt}) + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_110))?{c_110 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#145))))?{c#145 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#149))?{c#149 <- c_opt}) + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_112))?{c_112 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#148))))?{c#148 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#152))?{c#152 <- c_opt}) + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_114))?{c_114 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#151))))?{c#151 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#155))?{c#155 <- c_opt}) + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_116))?{c_116 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#154))))?{c#154 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#158))?{c#158 <- c_opt}) + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_118))?{c_118 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#157))))?{c#157 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#161))?{c#161 <- c_opt}) + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_120))?{c_120 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#160))))?{c#160 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#164))?{c#164 <- c_opt}) + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_122))?{c_122 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#163))))?{c#163 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#167))?{c#167 <- c_opt}) + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_124))?{c_124 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#166))))?{c#166 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#170))?{c#170 <- c_opt}) + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_126))?{c_126 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#169))))?{c#169 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#173))?{c#173 <- c_opt}) + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_128))?{c_128 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#172))))?{c#172 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#176))?{c#176 <- c_opt}) + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_130))?{c_130 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#175))))?{c#175 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#179))?{c#179 <- c_opt}) + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_132))?{c_132 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#178))))?{c#178 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#182))?{c#182 <- c_opt}) + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_134))?{c_134 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#181))))?{c#181 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#185))?{c#185 <- c_opt}) + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_136))?{c_136 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#184))))?{c#184 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#188))?{c#188 <- c_opt}) + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_138))?{c_138 <- c_opt})) -- let{c_opt : iN?} c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#187))))?{c#187 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#191))?{c#191 <- c_opt}) + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_140))?{c_140 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#190))))?{c#190 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#194))?{c#194 <- c_opt}) + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_142))?{c_142 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#193))))?{c#193 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#197))?{c#197 <- c_opt}) + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_144))?{c_144 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#196))))?{c#196 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#200))?{c#200 <- c_opt}) + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_146))?{c_146 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#199))))?{c#199 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#203))?{c#203 <- c_opt}) + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_148))?{c_148 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#202))))?{c#202 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#206))?{c#206 <- c_opt}) + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_150))?{c_150 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#205))))?{c#205 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#209))?{c#209 <- c_opt}) + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_152))?{c_152 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#208))))?{c#208 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#212))?{c#212 <- c_opt}) + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F32_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_154))?{c_154 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#211))))?{c#211 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#215))?{c#215 <- c_opt}) + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_156))?{c_156 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#214))))?{c#214 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#218))?{c#218 <- c_opt}) + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_158))?{c_158 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#217))))?{c#217 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#221))?{c#221 <- c_opt}) + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_160))?{c_160 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#220))))?{c#220 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I32_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#224))?{c#224 <- c_opt}) + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I32_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c_162))?{c_162 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I32_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, c#223))))?{c#223 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#227))?{c#227 <- c_opt}) + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_164))?{c_164 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#226))))?{c#226 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#230))?{c#230 <- c_opt}) + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_166))?{c_166 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#229))))?{c#229 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#233))?{c#233 <- c_opt}) + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_168))?{c_168 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#232))))?{c#232 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1, I64_Jnn, M_2, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#236))?{c#236 <- c_opt}) + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___2_vcvtop__(F64_Fnn, M_1_0, I64_Jnn, M_2_0, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(v_sx, zero_opt)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), lift(mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c_170))?{c_170 <- c_opt})) -- let{c_opt : iN?} c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_addrtype(I64_Inn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, c#235))))?{c#235 <- c_opt} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#239))*{c#239 <- c_lst} + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_172))*{c_172 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#238))))*{c#238 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#242))*{c#242 <- c_lst} + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_174))*{c_174 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#241))))*{c#241 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#245))*{c#245 <- c_lst} + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_176))*{c_176 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#244))))*{c#244 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#248))*{c#248 <- c_lst} + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_178))*{c_178 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#247))))*{c#247 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#251))*{c#251 <- c_lst} + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_180))*{c_180 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#250))))*{c#250 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#254))*{c#254 <- c_lst} + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_182))*{c_182 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#253))))*{c#253 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#257))*{c#257 <- c_lst} + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_184))*{c_184 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#256))))*{c#256 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#260))*{c#260 <- c_lst} + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero)), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_186))*{c_186 <- c_lst}) -- let{c_lst : fN*} c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#259))))*{c#259 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#263))*{c#263 <- c_lst} + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_188))*{c_188 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#262))))*{c#262 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#266))*{c#266 <- c_lst} + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_190))*{c_190 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#265))))*{c#265 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#269))*{c#269 <- c_lst} + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_192))*{c_192 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#268))))*{c#268 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F32_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#272))*{c#272 <- c_lst} + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F32_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F32_numtype, mk_num__1_num_(F32_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_194))*{c_194 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#271))))*{c#271 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#275))*{c#275 <- c_lst} + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_196))*{c_196 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#274))))*{c#274 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F32_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F32_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#278))*{c#278 <- c_lst} + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F32_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F32_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c_198))*{c_198 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, c#277))))*{c#277 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#281))*{c#281 <- c_lst} + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_200))*{c_200 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#280))))*{c#280 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN}(`%X%`_shape(F64_lanetype, `%`_dim(M_1)), `%X%`_shape(F64_lanetype, `%`_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1, F64_Fnn, M_2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1))) = mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#284))*{c#284 <- c_lst} + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(`%X%`_shape(F64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(F64_lanetype, mk_dim_dim(M_2)), mk_vcvtop___3_vcvtop__(F64_Fnn, M_1_0, F64_Fnn, M_2_0, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2), mk_lane__0_lane_(F64_numtype, mk_num__1_num_(F64_Fnn, c_1)), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c_202))*{c_202 <- c_lst}) -- let{c_lst : fN*} c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M_2))), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, c#283))))*{c#283 <- c_lst} + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation lcvtop___is_wf: `%%%%%`(shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__, v_lane_ : lane_, ret_val : lane_*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule lcvtop___is_wf_0{shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__, v_lane_ : lane_, ret_val : lane_*, var_0 : lane_*}: + `%%%%%`(shape_1, shape_2, v_vcvtop__, v_lane_, ret_val) + -- wf_shape: `%`(shape_1) + -- wf_shape: `%`(shape_2) + -- wf_vcvtop__: `%%%`(shape_1, shape_2, v_vcvtop__) + -- wf_lane_: `%%`($fun_lanetype(shape_1), v_lane_) + -- if (ret_val = var_0) + -- (wf_lane_: `%%`($fun_lanetype(shape_2), ret_val))*{ret_val <- ret_val} + -- fun_lcvtop__: `%%%%%`(shape_1, shape_2, v_vcvtop__, v_lane_, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vcvtop__(shape_1 : shape, shape_2 : shape, v_vcvtop__ : vcvtop__, v_vec_ : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vcvtop__{Lnn_1 : lanetype, v_M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, v_1) = v - -- if (($halfop(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop) = ?()) /\ ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop) = ?())) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(v_M)), v_1) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, c_1#142)*{c_1#142 <- c_1_lst}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(v_M)), c_lst#30)*{c_lst#30 <- c_lst_lst}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(v_M))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(v_M))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, v_half : half}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(v_half)) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$fun_half(v_half, 0, M_2) : M_2] - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#144)*{c_1#144 <- c_1_lst}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#32)*{c_lst#32 <- c_lst_lst}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vcvtop__{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1) - -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#146)*{c_1#146 <- c_1_lst} ++ [$fun_zero(Lnn_2)]^M_1{}) - -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#34)*{c_lst#34 <- c_lst_lst}) - -- wf_uN: `%%`(128, v) - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) +relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_0{Lnn_1 : lanetype, v_M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, M_0 : nat, var_2_lst : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(v_M)), `%X%`_shape(Lnn_2, mk_dim_dim(M_0)), vcvtop, v_1, v) + -- if ((var_0 = ?()) /\ (var_1 = ?())) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, mk_dim_dim(v_M)), v_1) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, var_2_lst) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(v_M)), c_lst_30)*{c_lst_30 <- c_lst_lst}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(v_M)), c_lst_30)*{c_lst_30 <- c_lst_lst}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, mk_dim_dim(v_M))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, mk_dim_dim(v_M))) + -- if (v_M = M_0) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(v_M)), `%X%`_shape(Lnn_2, mk_dim_dim(v_M)), vcvtop, c_1_142, var_2))*{var_2 <- var_2_lst, c_1_142 <- c_1_lst} + -- if (|var_2_lst| = |c_1_lst|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(v_M)), `%X%`_shape(Lnn_2, mk_dim_dim(v_M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(v_M)), `%X%`_shape(Lnn_2, mk_dim_dim(v_M)), vcvtop, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_1{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, v_half : half, var_1_lst : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(v_half)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), v_1)[$fun_half(v_half, 0, M_2) : M_2] + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, var_1_lst) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(M_2)), c_lst_32)*{c_lst_32 <- c_lst_lst}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(M_2)), c_lst_32)*{c_lst_32 <- c_lst_lst}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, mk_dim_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, c_1_144, var_1))*{var_1 <- var_1_lst, c_1_144 <- c_1_lst} + -- if (|var_1_lst| = |c_1_lst|) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, var_1_lst : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, v_1, v) + -- if (var_0 = ?(ZERO_zero)) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), v_1) + -- let{c_lst_lst : lane_**} c_lst_lst = $setproduct_(syntax lane_, var_1_lst ++ [$fun_zero(Lnn_2)]^M_1{}) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(M_2)), c_lst_34)*{c_lst_34 <- c_lst_lst}) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, mk_dim_dim(M_2)), c_lst_34)*{c_lst_34 <- c_lst_lst}| > 0) + -- wf_shape: `%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, mk_dim_dim(M_2))) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, c_1_146, var_1))*{var_1 <- var_1_lst, c_1_146 <- c_1_lst} + -- if (|var_1_lst| = |c_1_lst|) + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, mk_dim_dim(M_1)), `%X%`_shape(Lnn_2, mk_dim_dim(M_2)), vcvtop, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vshiftop_(v_ishape : ishape, v_vshiftop_ : vshiftop_, v_vec_ : vec_, v_u32 : u32) : vec_ +relation fun_vshiftop_: `%%%%%`(ishape, vshiftop_, vec_, u32, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I32_Jnn, v_M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_0{v_M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ishl_, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I64_Jnn, v_M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_1{v_M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ishl_, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I8_Jnn, v_M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_2{v_M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ishl_, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I16_Jnn, v_M, SHL_vshiftop_Jnn_M), v, i) = $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ishl_, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_3{v_M : nat, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHL_vshiftop_Jnn_M), v, i, $ivshiftop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ishl_, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v_sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I32_Jnn, v_M, SHR_vshiftop_Jnn_M(v_sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), def $ishr_, v_sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_4{v_M : nat, v_sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I32_Jnn, M_0, SHR_vshiftop_Jnn_M(v_sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), def $ishr_, v_sx, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v_sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I64_Jnn, v_M, SHR_vshiftop_Jnn_M(v_sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), def $ishr_, v_sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_5{v_M : nat, v_sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I64_Jnn, M_0, SHR_vshiftop_Jnn_M(v_sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), def $ishr_, v_sx, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v_sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I8_Jnn, v_M, SHR_vshiftop_Jnn_M(v_sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), def $ishr_, v_sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_6{v_M : nat, v_sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I8_Jnn, M_0, SHR_vshiftop_Jnn_M(v_sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), def $ishr_, v_sx, v, i)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vshiftop_{v_M : nat, v_sx : sx, v : uN, i : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(v_M))), mk_vshiftop__0_vshiftop_(I16_Jnn, v_M, SHR_vshiftop_Jnn_M(v_sx)), v, i) = $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), def $ishr_, v_sx, v, i) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vshiftop__case_7{v_M : nat, v_sx : sx, v : uN, i : uN, M_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M))), mk_vshiftop__0_vshiftop_(I16_Jnn, M_0, SHR_vshiftop_Jnn_M(v_sx)), v, i, $ivshiftopsx_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), def $ishr_, v_sx, v, i)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vbitmaskop_(v_ishape : ishape, v_vec_ : vec_) : u32 +relation fun_vbitmaskop_: `%%%`(ishape, vec_, u32) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{v_M : nat, v : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(v_M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + rule fun_vbitmaskop__case_0{v_M : nat, v : uN, var_0 : u32}: + `%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(v_M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{v_M : nat, v : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(v_M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + rule fun_vbitmaskop__case_1{v_M : nat, v : uN, var_0 : u32}: + `%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(v_M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{v_M : nat, v : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + rule fun_vbitmaskop__case_2{v_M : nat, v : uN, var_0 : u32}: + `%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(v_M)), v, var_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vbitmaskop_{v_M : nat, v : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(v_M))), v) = $ivbitmaskop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + rule fun_vbitmaskop__case_3{v_M : nat, v : uN, var_0 : u32}: + `%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(v_M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vswizzlop_(v_bshape : bshape, v_vswizzlop_ : vswizzlop_, v_vec_ : vec_, v_vec__0 : vec_) : vec_ +relation fun_vswizzlop_: `%%%%%`(bshape, vswizzlop_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vswizzlop_{v_M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), mk_vswizzlop__0_vswizzlop_(v_M, SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $iswizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M))) + rule fun_vswizzlop__case_0{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), mk_vswizzlop__0_vswizzlop_(M_0, SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $iswizzle_lane_, v_1, v_2)) + -- if (v_M = M_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vswizzlop_{v_M : nat, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), mk_vswizzlop__0_vswizzlop_(v_M, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2) = $ivswizzlop_(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), def $irelaxed_swizzle_lane_, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M))) + rule fun_vswizzlop__case_1{v_M : nat, v_1 : uN, v_2 : uN, M_0 : nat}: + `%%%%%`(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), mk_vswizzlop__0_vswizzlop_(M_0, RELAXED_SWIZZLE_vswizzlop_M), v_1, v_2, $ivswizzlop_(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), def $irelaxed_swizzle_lane_, v_1, v_2)) + -- if (v_M = M_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vshufflop_(v_bshape : bshape, var_0 : laneidx*, v_vec_ : vec_, v_vec__0 : vec_) : vec_ +relation fun_vshufflop_: `%%%%%`(bshape, laneidx*, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN}(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), i_lst, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2) - -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M))) + rule fun_vshufflop__case_0{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: + `%%%%%`(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M))), i_lst, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(v_M)), i_lst, v_1, v_2, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_vec__0 : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#148)))*{c_1#148 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#100)))*{c_2#100 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#2)*{c'_1#2 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2#2)*{c'_2#2 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#3)))*{c'_1#3 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#3)))*{c'_2#3 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#150)))*{c_1#150 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#102)))*{c_2#102 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#5)*{c'_1#5 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2#5)*{c'_2#5 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#6)))*{c'_1#6 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#6)))*{c'_2#6 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#152)))*{c_1#152 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#104)))*{c_2#104 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#8)*{c'_1#8 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2#8)*{c'_2#8 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#9)))*{c'_1#9 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#9)))*{c'_2#9 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#154)))*{c_1#154 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#106)))*{c_2#106 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#11)*{c'_1#11 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2#11)*{c'_2#11 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1#12)))*{c'_1#12 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#12)))*{c'_2#12 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#156)))*{c_1#156 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#108)))*{c_2#108 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#14)*{c'_1#14 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2#14)*{c'_2#14 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#15)))*{c'_1#15 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#15)))*{c'_2#15 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#158)))*{c_1#158 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#110)))*{c_2#110 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#17)*{c'_1#17 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2#17)*{c'_2#17 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#18)))*{c'_1#18 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#18)))*{c'_2#18 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#160)))*{c_1#160 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#112)))*{c_2#112 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#20)*{c'_1#20 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2#20)*{c'_2#20 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#21)))*{c'_1#21 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#21)))*{c'_2#21 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#162)))*{c_1#162 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#114)))*{c_2#114 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#23)*{c'_1#23 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2#23)*{c'_2#23 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1#24)))*{c'_1#24 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#24)))*{c'_2#24 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#164)))*{c_1#164 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#116)))*{c_2#116 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#26)*{c'_1#26 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2#26)*{c'_2#26 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#27)))*{c'_1#27 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#27)))*{c'_2#27 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#166)))*{c_1#166 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#118)))*{c_2#118 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#29)*{c'_1#29 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2#29)*{c'_2#29 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#30)))*{c'_1#30 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#30)))*{c'_2#30 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#168)))*{c_1#168 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#32)*{c'_1#32 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2#32)*{c'_2#32 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#33)))*{c'_1#33 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#33)))*{c'_2#33 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#170)))*{c_1#170 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#122)))*{c_2#122 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#35)*{c'_1#35 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2#35)*{c'_2#35 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1#36)))*{c'_1#36 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#36)))*{c'_2#36 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#172)))*{c_1#172 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#124)))*{c_2#124 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#38)*{c'_1#38 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2#38)*{c'_2#38 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#39)))*{c'_1#39 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#39)))*{c'_2#39 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#174)))*{c_1#174 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#41)*{c'_1#41 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2#41)*{c'_2#41 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#42)))*{c'_1#42 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#42)))*{c'_2#42 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#176)))*{c_1#176 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#128)))*{c_2#128 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#44)*{c'_1#44 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2#44)*{c'_2#44 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#45)))*{c'_1#45 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#45)))*{c'_2#45 <- c'_2_lst} - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $vnarrowop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2) - -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#178)))*{c_1#178 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#130)))*{c_2#130 <- c_2_lst} - -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#47)*{c'_1#47 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2#47)*{c'_2#47 <- c'_2_lst}) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1#48)))*{c'_1#48 <- c'_1_lst} - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#48)))*{c'_2#48 <- c'_2_lst} +relation fun_vnarrowop__: `%%%%%%`(shape, shape, sx, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_0{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_148)))*{c_1_148 <- c_1_lst} + -- (if ($proj_lane__2(c_1_148) =/= ?()))*{c_1_148 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2_100)))*{c_2_100 <- c_2_lst} + -- (if ($proj_lane__2(c_2_100) =/= ?()))*{c_2_100 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1_2)*{c'_1_2 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2_2)*{c'_2_2 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1_3)))*{c'_1_3 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2_3)))*{c'_2_3 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_1{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_150)))*{c_1_150 <- c_1_lst} + -- (if ($proj_lane__2(c_1_150) =/= ?()))*{c_1_150 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2_102)))*{c_2_102 <- c_2_lst} + -- (if ($proj_lane__2(c_2_102) =/= ?()))*{c_2_102 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1_5)*{c'_1_5 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2_5)*{c'_2_5 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1_6)))*{c'_1_6 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2_6)))*{c'_2_6 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_2{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_152)))*{c_1_152 <- c_1_lst} + -- (if ($proj_lane__2(c_1_152) =/= ?()))*{c_1_152 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2_104)))*{c_2_104 <- c_2_lst} + -- (if ($proj_lane__2(c_2_104) =/= ?()))*{c_2_104 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1_8)*{c'_1_8 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2_8)*{c'_2_8 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1_9)))*{c'_1_9 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2_9)))*{c'_2_9 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_3{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_154)))*{c_1_154 <- c_1_lst} + -- (if ($proj_lane__2(c_1_154) =/= ?()))*{c_1_154 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2_106)))*{c_2_106 <- c_2_lst} + -- (if ($proj_lane__2(c_2_106) =/= ?()))*{c_2_106 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1_11)*{c'_1_11 <- c'_1_lst} ++ mk_lane__2_lane_(I32_Jnn, c'_2_11)*{c'_2_11 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_1_12)))*{c'_1_12 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2_12)))*{c'_2_12 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_4{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_156)))*{c_1_156 <- c_1_lst} + -- (if ($proj_lane__2(c_1_156) =/= ?()))*{c_1_156 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2_108)))*{c_2_108 <- c_2_lst} + -- (if ($proj_lane__2(c_2_108) =/= ?()))*{c_2_108 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1_14)*{c'_1_14 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2_14)*{c'_2_14 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1_15)))*{c'_1_15 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2_15)))*{c'_2_15 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_5{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_158)))*{c_1_158 <- c_1_lst} + -- (if ($proj_lane__2(c_1_158) =/= ?()))*{c_1_158 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2_110)))*{c_2_110 <- c_2_lst} + -- (if ($proj_lane__2(c_2_110) =/= ?()))*{c_2_110 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1_17)*{c'_1_17 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2_17)*{c'_2_17 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1_18)))*{c'_1_18 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2_18)))*{c'_2_18 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_6{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_160)))*{c_1_160 <- c_1_lst} + -- (if ($proj_lane__2(c_1_160) =/= ?()))*{c_1_160 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2_112)))*{c_2_112 <- c_2_lst} + -- (if ($proj_lane__2(c_2_112) =/= ?()))*{c_2_112 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1_20)*{c'_1_20 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2_20)*{c'_2_20 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1_21)))*{c'_1_21 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2_21)))*{c'_2_21 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_7{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_162)))*{c_1_162 <- c_1_lst} + -- (if ($proj_lane__2(c_1_162) =/= ?()))*{c_1_162 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2_114)))*{c_2_114 <- c_2_lst} + -- (if ($proj_lane__2(c_2_114) =/= ?()))*{c_2_114 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1_23)*{c'_1_23 <- c'_1_lst} ++ mk_lane__2_lane_(I64_Jnn, c'_2_23)*{c'_2_23 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_1_24)))*{c'_1_24 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2_24)))*{c'_2_24 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_8{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_164)))*{c_1_164 <- c_1_lst} + -- (if ($proj_lane__2(c_1_164) =/= ?()))*{c_1_164 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2_116)))*{c_2_116 <- c_2_lst} + -- (if ($proj_lane__2(c_2_116) =/= ?()))*{c_2_116 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1_26)*{c'_1_26 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2_26)*{c'_2_26 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1_27)))*{c'_1_27 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2_27)))*{c'_2_27 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_9{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_166)))*{c_1_166 <- c_1_lst} + -- (if ($proj_lane__2(c_1_166) =/= ?()))*{c_1_166 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2_118)))*{c_2_118 <- c_2_lst} + -- (if ($proj_lane__2(c_2_118) =/= ?()))*{c_2_118 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1_29)*{c'_1_29 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2_29)*{c'_2_29 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1_30)))*{c'_1_30 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2_30)))*{c'_2_30 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_10{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_168)))*{c_1_168 <- c_1_lst} + -- (if ($proj_lane__2(c_1_168) =/= ?()))*{c_1_168 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2_120)))*{c_2_120 <- c_2_lst} + -- (if ($proj_lane__2(c_2_120) =/= ?()))*{c_2_120 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1_32)*{c'_1_32 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2_32)*{c'_2_32 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1_33)))*{c'_1_33 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2_33)))*{c'_2_33 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_11{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_170)))*{c_1_170 <- c_1_lst} + -- (if ($proj_lane__2(c_1_170) =/= ?()))*{c_1_170 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2_122)))*{c_2_122 <- c_2_lst} + -- (if ($proj_lane__2(c_2_122) =/= ?()))*{c_2_122 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1_35)*{c'_1_35 <- c'_1_lst} ++ mk_lane__2_lane_(I8_Jnn, c'_2_35)*{c'_2_35 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_1_36)))*{c'_1_36 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2_36)))*{c'_2_36 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_12{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_172)))*{c_1_172 <- c_1_lst} + -- (if ($proj_lane__2(c_1_172) =/= ?()))*{c_1_172 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2_124)))*{c_2_124 <- c_2_lst} + -- (if ($proj_lane__2(c_2_124) =/= ?()))*{c_2_124 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1_38)*{c'_1_38 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2_38)*{c'_2_38 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1_39)))*{c'_1_39 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2_39)))*{c'_2_39 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_13{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_174)))*{c_1_174 <- c_1_lst} + -- (if ($proj_lane__2(c_1_174) =/= ?()))*{c_1_174 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2_126)))*{c_2_126 <- c_2_lst} + -- (if ($proj_lane__2(c_2_126) =/= ?()))*{c_2_126 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1_41)*{c'_1_41 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2_41)*{c'_2_41 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1_42)))*{c'_1_42 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2_42)))*{c'_2_42 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_14{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_176)))*{c_1_176 <- c_1_lst} + -- (if ($proj_lane__2(c_1_176) =/= ?()))*{c_1_176 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2_128)))*{c_2_128 <- c_2_lst} + -- (if ($proj_lane__2(c_2_128) =/= ?()))*{c_2_128 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1_44)*{c'_1_44 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2_44)*{c'_2_44 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1_45)))*{c'_1_45 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2_45)))*{c'_2_45 <- c'_2_lst} + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vnarrowop___case_15{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN}: + `%%%%%%`(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), v_sx, v_1, v_2, v) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2) + -- let{c'_1_lst : iN*} c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_178)))*{c_1_178 <- c_1_lst} + -- (if ($proj_lane__2(c_1_178) =/= ?()))*{c_1_178 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2_130)))*{c_2_130 <- c_2_lst} + -- (if ($proj_lane__2(c_2_130) =/= ?()))*{c_2_130 <- c_2_lst} + -- let{v : vec_} v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1_47)*{c'_1_47 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2_47)*{c'_2_47 <- c'_2_lst}) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_1_48)))*{c'_1_48 <- c'_1_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2_48)))*{c'_2_48 <- c'_2_lst} ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivadd_pairwise_(v_N : N, var_0 : iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivadd_pairwise_{v_N : nat, i_lst : iN*, j_1_lst : N*, j_2_lst : N*}(v_N, i_lst) = $iadd_(v_N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- j_1_lst, j_2 <- j_2_lst} - -- if ($concat_(syntax N, [j_1#1 j_2#1]*{j_1#1 <- j_1_lst, j_2#1 <- j_2_lst}) = $proj_uN_0(i#139992).0*{i#139992 <- i_lst}) - -- (wf_uN: `%%`(v_N, `%`_uN(j_1#2)))*{j_1#2 <- j_1_lst} - -- (wf_uN: `%%`(v_N, `%`_uN(j_2#2)))*{j_2#2 <- j_2_lst} + def $ivadd_pairwise_{v_N : nat, i_lst : iN*, j_1_lst : N*, j_2_lst : N*}(v_N, i_lst) = $iadd_(v_N, mk_uN_iN(j_1), mk_uN_iN(j_2))*{j_1 <- j_1_lst, j_2 <- j_2_lst} + -- if ($concat_(syntax N, [j_1_1 j_2_1]*{j_1_1 <- j_1_lst, j_2_1 <- j_2_lst}) = $proj_uN_0(i_139676).0*{i_139676 <- i_lst}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#293)*{c#293 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- c_1_lst} + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_210)*{c_210 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_180)))*{c_1_180 <- c_1_lst} -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#292)))*{c#292 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#296)*{c#296 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#182)))*{c_1#182 <- c_1_lst} + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_212)*{c_212 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_182)))*{c_1_182 <- c_1_lst} -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#295)))*{c#295 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#299)*{c#299 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#184)))*{c_1#184 <- c_1_lst} + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_214)*{c_214 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_184)))*{c_1_184 <- c_1_lst} -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#298)))*{c#298 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_216)*{c_216 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1_186)))*{c_1_186 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_218)*{c_218 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_188)))*{c_1_188 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_220)*{c_220 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_190)))*{c_1_190 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_222)*{c_222 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_192)))*{c_1_192 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_224)*{c_224 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1_194)))*{c_1_194 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_226)*{c_226 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_196)))*{c_1_196 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_228)*{c_228 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_198)))*{c_1_198 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_230)*{c_230 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_200)))*{c_1_200 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_232)*{c_232 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1_202)))*{c_1_202 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_234)*{c_234 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_204)))*{c_1_204 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_236)*{c_236 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_206)))*{c_1_206 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_238)*{c_238 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_208)))*{c_1_208 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_240)*{c_240 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1) + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1_210)))*{c_1_210 <- c_1_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vextunop__: `%%%%%`(ishape, ishape, vextunop__, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_0{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_1{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_2{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_3{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_4{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_5{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_6{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_7{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_8{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_9{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_10{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_11{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_12{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_13{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_14{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextunop___case_15{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1, $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivdot_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivdot_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*, j_1_lst : iN*, j_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $iadd_(v_N, j_1, j_2)*{j_1 <- j_1_lst, j_2 <- j_2_lst} + -- if ($concat_(syntax iN, [j_1_2 j_2_2]*{j_1_2 <- j_1_lst, j_2_2 <- j_2_lst}) = $imul_(v_N, i_1_2, i_2_2)*{i_1_2 <- i_1_lst, i_2_2 <- i_2_lst}) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivdot_sat_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivdot_sat_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*, j_1_lst : iN*, j_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $iadd_sat_(v_N, S_sx, j_1, j_2)*{j_1 <- j_1_lst, j_2 <- j_2_lst} + -- if ($concat_(syntax iN, [j_1_3 j_2_3]*{j_1_3 <- j_1_lst, j_2_3 <- j_2_lst}) = $imul_(v_N, i_1_4, i_2_4)*{i_1_4 <- i_1_lst, i_2_4 <- i_2_lst}) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(v_N : N, iN*, iN*) : iN*, v_sx : sx, v_sx_0 : sx, v_laneidx : laneidx, v_laneidx_0 : laneidx, v_vec_ : vec_, v_vec__0 : vec_) : vec_ + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_242)*{c_242 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1_212)))*{c_1_212 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2_132)))*{c_2_132 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_244)*{c_244 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1_214)))*{c_1_214 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2_134)))*{c_2_134 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_246)*{c_246 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1_216)))*{c_1_216 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2_136)))*{c_2_136 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I32_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c_248)*{c_248 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1_218)))*{c_1_218 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2_138)))*{c_2_138 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_250)*{c_250 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1_220)))*{c_1_220 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2_140)))*{c_2_140 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_252)*{c_252 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1_222)))*{c_1_222 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2_142)))*{c_2_142 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_254)*{c_254 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1_224)))*{c_1_224 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2_144)))*{c_2_144 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I64_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c_256)*{c_256 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1_226)))*{c_1_226 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2_146)))*{c_2_146 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_258)*{c_258 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1_228)))*{c_1_228 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2_148)))*{c_2_148 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_260)*{c_260 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1_230)))*{c_1_230 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2_150)))*{c_2_150 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_262)*{c_262 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1_232)))*{c_1_232 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2_152)))*{c_2_152 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I8_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c_264)*{c_264 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1_234)))*{c_1_234 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2_154)))*{c_2_154 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_266)*{c_266 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1_236)))*{c_1_236 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2_156)))*{c_2_156 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_268)*{c_268 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1_238)))*{c_1_238 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2_158)))*{c_2_158 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_270)*{c_270 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1_240)))*{c_1_240 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2_160)))*{c_2_160 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1)), `%X%`_shape(I16_lanetype, mk_dim_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c_272)*{c_272 <- c_lst}) + -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] + -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1_242)))*{c_1_242 <- c_1_lst} + -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2_162)))*{c_2_162 <- c_2_lst} + -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))) + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +def $ivmul_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivmul_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $imul_(v_N, i_1, i_2)*{i_1 <- i_1_lst, i_2 <- i_2_lst} + +;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec +relation fun_vextbinop__: `%%%%%%`(ishape, ishape, vextbinop__, vec_, vec_, vec_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_0{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_1{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_2{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_3{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_4{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_5{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_6{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_7{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_8{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_9{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_10{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_11{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_12{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_13{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#302)*{c#302 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#301)))*{c#301 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_14{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#305)*{c#305 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#188)))*{c_1#188 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#304)))*{c#304 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_15{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivmul_, v_sx, v_sx, mk_uN_laneidx($fun_half(v_half, 0, M_2)), mk_uN_laneidx(M_2), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#308)*{c#308 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#190)))*{c_1#190 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#307)))*{c#307 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_16{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#311)*{c#311 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#310)))*{c#310 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_17{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#314)*{c#314 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#194)))*{c_1#194 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#313)))*{c#313 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_18{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#317)*{c#317 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#196)))*{c_1#196 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#316)))*{c#316 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_19{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#320)*{c#320 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#319)))*{c#319 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_20{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#323)*{c#323 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#200)))*{c_1#200 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#322)))*{c#322 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_21{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#326)*{c#326 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#202)))*{c_1#202 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#325)))*{c#325 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_22{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#329)*{c#329 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#328)))*{c#328 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_23{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#332)*{c#332 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#206)))*{c_1#206 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#331)))*{c#331 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_24{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#335)*{c#335 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#208)))*{c_1#208 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#334)))*{c#334 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_25{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextunop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*) : iN*, v_sx : sx, v_1 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, v_sx, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#338)*{c#338 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1) - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- c_1_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#337)))*{c#337 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_26{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vextunop__(ishape_1 : ishape, ishape_2 : ishape, v_vextunop__ : vextunop__, v_vec_ : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_27{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_28{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_29{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_30{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_31{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_, S_sx, S_sx, mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_32{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_33{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_34{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_35{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_36{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_37{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_38{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_39{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_40{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_41{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextunop__{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextunop___0_vextunop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(v_sx)), v_1) = $ivextunop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivadd_pairwise_, v_sx, v_1) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) + rule fun_vextbinop___case_42{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*, j_1_lst : iN*, j_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $iadd_(v_N, j_1, j_2)*{j_1 <- j_1_lst, j_2 <- j_2_lst} - -- if ($concat_(syntax iN, [j_1#3 j_2#3]*{j_1#3 <- j_1_lst, j_2#3 <- j_2_lst}) = $imul_(v_N, i_1#2, i_2#2)*{i_1#2 <- i_1_lst, i_2#2 <- i_2_lst}) - -- (wf_uN: `%%`(v_N, j_1#4))*{j_1#4 <- j_1_lst} - -- (wf_uN: `%%`(v_N, j_2#4))*{j_2#4 <- j_2_lst} + rule fun_vextbinop___case_43{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivdot_sat_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivdot_sat_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*, j_1_lst : iN*, j_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $iadd_sat_(v_N, S_sx, j_1, j_2)*{j_1 <- j_1_lst, j_2 <- j_2_lst} - -- if ($concat_(syntax iN, [j_1#5 j_2#5]*{j_1#5 <- j_1_lst, j_2#5 <- j_2_lst}) = $imul_(v_N, i_1#4, i_2#4)*{i_1#4 <- i_1_lst, i_2#4 <- i_2_lst}) - -- (wf_uN: `%%`(v_N, j_1#6))*{j_1#6 <- j_1_lst} - -- (wf_uN: `%%`(v_N, j_2#6))*{j_2#6 <- j_2_lst} + rule fun_vextbinop___case_44{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivextbinop__(shape_1 : shape, shape_2 : shape, def $f_(v_N : N, iN*, iN*) : iN*, v_sx : sx, v_sx_0 : sx, v_laneidx : laneidx, v_laneidx_0 : laneidx, v_vec_ : vec_, v_vec__0 : vec_) : vec_ ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#341)*{c#341 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#212)))*{c_1#212 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#132)))*{c_2#132 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#340)))*{c#340 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#344)*{c#344 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#214)))*{c_1#214 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#134)))*{c_2#134 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#343)))*{c#343 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#347)*{c#347 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#216)))*{c_1#216 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#136)))*{c_2#136 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#346)))*{c#346 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c#350)*{c#350 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#218)))*{c_1#218 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#138)))*{c_2#138 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c#349)))*{c#349 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#353)*{c#353 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#220)))*{c_1#220 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#140)))*{c_2#140 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#352)))*{c#352 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#356)*{c#356 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#222)))*{c_1#222 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#142)))*{c_2#142 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#355)))*{c#355 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#359)*{c#359 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#224)))*{c_1#224 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#144)))*{c_2#144 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#358)))*{c#358 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c#362)*{c#362 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#226)))*{c_1#226 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#146)))*{c_2#146 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c#361)))*{c#361 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#365)*{c#365 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#228)))*{c_1#228 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#148)))*{c_2#148 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#364)))*{c#364 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#368)*{c#368 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#230)))*{c_1#230 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#150)))*{c_2#150 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#367)))*{c#367 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#371)*{c#371 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#232)))*{c_1#232 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#152)))*{c_2#152 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#370)))*{c#370 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c#374)*{c#374 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#234)))*{c_1#234 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#154)))*{c_2#154 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c#373)))*{c#373 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#377)*{c#377 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#236)))*{c_1#236 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#156)))*{c_2#156 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#376)))*{c#376 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#380)*{c#380 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#238)))*{c_1#238 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#158)))*{c_2#158 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#379)))*{c#379 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#383)*{c#383 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#240)))*{c_1#240 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#160)))*{c_2#160 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#382)))*{c#382 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivextbinop__{M_1 : nat, M_2 : nat, def $f_(v_N : N, iN*, iN*) : iN*, sx_1 : sx, sx_2 : sx, i : uN, k : uN, v_1 : uN, v_2 : uN}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), def $f_, sx_1, sx_2, i, k, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c#386)*{c#386 <- c_lst}) - -- let{c_1_lst : lane_*} c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c_2_lst : lane_*} c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0] - -- let{c'_1_lst : iN*} c'_1_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#242)))*{c_1#242 <- c_1_lst} - -- let{c'_2_lst : iN*} c'_2_lst = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#162)))*{c_2#162 <- c_2_lst} - -- let{c_lst : iN*} c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst, c'_2_lst) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c#385)))*{c#385 <- c_lst} - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + rule fun_vextbinop___case_45{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivmul_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivmul_{v_N : nat, i_1_lst : iN*, i_2_lst : iN*}(v_N, i_1_lst, i_2_lst) = $imul_(v_N, i_1, i_2)*{i_1 <- i_1_lst, i_2 <- i_2_lst} + rule fun_vextbinop___case_46{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) -;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vextbinop__(ishape_1 : ishape, ishape_2 : ishape, v_vextbinop__ : vextbinop__, v_vec_ : vec_, v_vec__0 : vec_) : vec_ - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_half : half, v_sx : sx, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(v_half, v_sx)), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivmul_, v_sx, v_sx, `%`_laneidx($fun_half(v_half, 0, M_2)), `%`_laneidx(M_2), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN($fun_half(v_half, 0, M_2))) - -- wf_uN: `%%`(8, `%`_uN(M_2)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_, S_sx, S_sx, `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextbinop__{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2) = $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), `%`_laneidx(0), `%`_laneidx(M_1), v_1, v_2) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_uN: `%%`(8, `%`_uN(0)) - -- wf_uN: `%%`(8, `%`_uN(M_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextbinop___case_47{M_1 : nat, M_2 : nat, v_1 : uN, v_2 : uN, M_1_0 : nat, M_2_0 : nat}: + `%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), v_1, v_2, $ivextbinop__(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)), `%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), def $ivdot_sat_, S_sx, $fun_relaxed2($R_idot, syntax sx, S_sx, U_sx), mk_uN_laneidx(0), mk_uN_laneidx(M_1), v_1, v_2)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vextternop__, v_vec_ : vec_, v_vec__0 : vec_, v_vec__1 : vec_) : vec_ +relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + rule fun_vextternop___case_0{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_1{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_2{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_3{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I32_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I32_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_4{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_5{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_6{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_7{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I64_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I64_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_8{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_9{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_10{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_11{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I8_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I8_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_12{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I32_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I32_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I32_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_13{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I64_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I64_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I64_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_14{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I8_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) - ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $fun_vextternop__{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn}(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_1))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3) = c + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I8_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I8_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vextternop___case_15{M_1 : nat, M_2 : nat, c_1 : uN, c_2 : uN, c_3 : uN, c : uN, v_Jnn : Jnn, M_1_0 : nat, M_2_0 : nat, var_2 : vec_*, var_1 : vec_, var_0 : vec_}: + `%%%%%%%`(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(M_2))), mk_vextternop___0_vextternop__(I16_Jnn, M_1_0, I16_Jnn, M_2_0, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, c) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- let{v_M : M} v_M = (2 * M_2) - -- let{c' : vec_} c' = $fun_vextbinop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2) - -- let{c'' : vec_} c'' = $fun_vextunop__(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c') - -- if (c <- $fun_vbinop_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3)) - -- wf_uN: `%%`(128, c) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)))) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)))) - -- wf_vextbinop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), `%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) - -- wf_ishape: `%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)))) - -- wf_vextunop__: `%%%`(`%`_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), `%`_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))) - -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- let{c' : vec_} c' = var_0 + -- let{c'' : vec_} c'' = var_1 + -- if (c <- var_2) + -- if (|var_2| > 0) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1)))) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)))) + -- wf_vextbinop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + -- wf_ishape: `%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)))) + -- wf_vextunop__: `%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))) + -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) + -- if (M_1 = M_1_0) + -- if (M_2 = M_2_0) + -- fun_vbinop_: `%%%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M), c'', c_3, var_2) + -- fun_vextunop__: `%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_2))), mk_vextunop___0_vextunop__(v_Jnn, v_M, I16_Jnn, M_2, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx)), c', var_1) + -- fun_vextbinop__: `%%%%%%`(mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(I16_Jnn), mk_dim_dim(M_1))), mk_ishape_ishape(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_vextbinop___0_vextbinop__(I16_Jnn, M_1, v_Jnn, v_M, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11450,7 +14979,7 @@ relation wf_vec: `%`(vec) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax result = | _VALS(val_lst : val*) - | `(REF.EXN_ADDR%)THROW_REF`(v_exnaddr : exnaddr) + | `(REF_EXN_ADDR%)THROW_REF`(v_exnaddr : exnaddr) | TRAP ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11462,7 +14991,7 @@ relation wf_result: `%`(result) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule result_case_1{v_exnaddr : exnaddr}: - `%`(`(REF.EXN_ADDR%)THROW_REF`_result(v_exnaddr)) + `%`(`(REF_EXN_ADDR%)THROW_REF`_result(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule result_case_2: @@ -11470,12 +14999,12 @@ relation wf_result: `%`(result) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax hostfunc = - | `...` + | mk_hostfunc ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax funccode = | FUNC(v_typeidx : typeidx, local_lst : local*, v_expr : expr) - | `...` + | mk_funccode def $funccode_func(var_0 : func) : funccode def $funccode_func{x0 : typeidx, x1 : local*, x2 : expr}(FUNC_func(x0, x1, x2)) = FUNC_funccode(x0, x1, x2) @@ -11491,7 +15020,7 @@ relation wf_funccode: `%`(funccode) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule funccode_case_1: - `%`(`...`_funccode) + `%`(mk_funccode_funccode) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax taginst = @@ -11610,40 +15139,40 @@ relation wf_packval: `%`(packval) syntax fieldval = | CONST(v_numtype : numtype, num_) | VCONST(v_vectype : vectype, vec_) - | `REF.I31_NUM`(v_u31 : u31) - | `REF.NULL_ADDR` - | `REF.STRUCT_ADDR`(v_structaddr : structaddr) - | `REF.ARRAY_ADDR`(v_arrayaddr : arrayaddr) - | `REF.FUNC_ADDR`(v_funcaddr : funcaddr) - | `REF.EXN_ADDR`(v_exnaddr : exnaddr) - | `REF.HOST_ADDR`(v_hostaddr : hostaddr) - | `REF.EXTERN`(v_ref : ref) + | REF_I31_NUM(v_u31 : u31) + | REF_NULL_ADDR + | REF_STRUCT_ADDR(v_structaddr : structaddr) + | REF_ARRAY_ADDR(v_arrayaddr : arrayaddr) + | REF_FUNC_ADDR(v_funcaddr : funcaddr) + | REF_EXN_ADDR(v_exnaddr : exnaddr) + | REF_HOST_ADDR(v_hostaddr : hostaddr) + | REF_EXTERN(v_ref : ref) | PACK(v_packtype : packtype, iN) def $fieldval_packval(var_0 : packval) : fieldval def $fieldval_packval{x0 : packtype, x1 : iN}(PACK_packval(x0, x1)) = PACK_fieldval(x0, x1) def $fieldval_ref(var_0 : ref) : fieldval - def $fieldval_ref{x0 : u31}(`REF.I31_NUM`_ref(x0)) = `REF.I31_NUM`_fieldval(x0) - def $fieldval_ref(`REF.NULL_ADDR`_ref) = `REF.NULL_ADDR`_fieldval - def $fieldval_ref{x0 : structaddr}(`REF.STRUCT_ADDR`_ref(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) - def $fieldval_ref{x0 : arrayaddr}(`REF.ARRAY_ADDR`_ref(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) - def $fieldval_ref{x0 : funcaddr}(`REF.FUNC_ADDR`_ref(x0)) = `REF.FUNC_ADDR`_fieldval(x0) - def $fieldval_ref{x0 : exnaddr}(`REF.EXN_ADDR`_ref(x0)) = `REF.EXN_ADDR`_fieldval(x0) - def $fieldval_ref{x0 : hostaddr}(`REF.HOST_ADDR`_ref(x0)) = `REF.HOST_ADDR`_fieldval(x0) - def $fieldval_ref{x0 : ref}(`REF.EXTERN`_ref(x0)) = `REF.EXTERN`_fieldval(x0) + def $fieldval_ref{x0 : u31}(REF_I31_NUM_ref(x0)) = REF_I31_NUM_fieldval(x0) + def $fieldval_ref(REF_NULL_ADDR_ref) = REF_NULL_ADDR_fieldval + def $fieldval_ref{x0 : structaddr}(REF_STRUCT_ADDR_ref(x0)) = REF_STRUCT_ADDR_fieldval(x0) + def $fieldval_ref{x0 : arrayaddr}(REF_ARRAY_ADDR_ref(x0)) = REF_ARRAY_ADDR_fieldval(x0) + def $fieldval_ref{x0 : funcaddr}(REF_FUNC_ADDR_ref(x0)) = REF_FUNC_ADDR_fieldval(x0) + def $fieldval_ref{x0 : exnaddr}(REF_EXN_ADDR_ref(x0)) = REF_EXN_ADDR_fieldval(x0) + def $fieldval_ref{x0 : hostaddr}(REF_HOST_ADDR_ref(x0)) = REF_HOST_ADDR_fieldval(x0) + def $fieldval_ref{x0 : ref}(REF_EXTERN_ref(x0)) = REF_EXTERN_fieldval(x0) def $fieldval_val(var_0 : val) : fieldval def $fieldval_val{x0 : numtype, x1 : num_}(CONST_val(x0, x1)) = CONST_fieldval(x0, x1) def $fieldval_val{x0 : vectype, x1 : vec_}(VCONST_val(x0, x1)) = VCONST_fieldval(x0, x1) - def $fieldval_val{x0 : u31}(`REF.I31_NUM`_val(x0)) = `REF.I31_NUM`_fieldval(x0) - def $fieldval_val(`REF.NULL_ADDR`_val) = `REF.NULL_ADDR`_fieldval - def $fieldval_val{x0 : structaddr}(`REF.STRUCT_ADDR`_val(x0)) = `REF.STRUCT_ADDR`_fieldval(x0) - def $fieldval_val{x0 : arrayaddr}(`REF.ARRAY_ADDR`_val(x0)) = `REF.ARRAY_ADDR`_fieldval(x0) - def $fieldval_val{x0 : funcaddr}(`REF.FUNC_ADDR`_val(x0)) = `REF.FUNC_ADDR`_fieldval(x0) - def $fieldval_val{x0 : exnaddr}(`REF.EXN_ADDR`_val(x0)) = `REF.EXN_ADDR`_fieldval(x0) - def $fieldval_val{x0 : hostaddr}(`REF.HOST_ADDR`_val(x0)) = `REF.HOST_ADDR`_fieldval(x0) - def $fieldval_val{x0 : ref}(`REF.EXTERN`_val(x0)) = `REF.EXTERN`_fieldval(x0) + def $fieldval_val{x0 : u31}(REF_I31_NUM_val(x0)) = REF_I31_NUM_fieldval(x0) + def $fieldval_val(REF_NULL_ADDR_val) = REF_NULL_ADDR_fieldval + def $fieldval_val{x0 : structaddr}(REF_STRUCT_ADDR_val(x0)) = REF_STRUCT_ADDR_fieldval(x0) + def $fieldval_val{x0 : arrayaddr}(REF_ARRAY_ADDR_val(x0)) = REF_ARRAY_ADDR_fieldval(x0) + def $fieldval_val{x0 : funcaddr}(REF_FUNC_ADDR_val(x0)) = REF_FUNC_ADDR_fieldval(x0) + def $fieldval_val{x0 : exnaddr}(REF_EXN_ADDR_val(x0)) = REF_EXN_ADDR_fieldval(x0) + def $fieldval_val{x0 : hostaddr}(REF_HOST_ADDR_val(x0)) = REF_HOST_ADDR_fieldval(x0) + def $fieldval_val{x0 : ref}(REF_EXTERN_val(x0)) = REF_EXTERN_fieldval(x0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_fieldval: `%`(fieldval) @@ -11659,36 +15188,36 @@ relation wf_fieldval: `%`(fieldval) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_2{v_u31 : u31}: - `%`(`REF.I31_NUM`_fieldval(v_u31)) + `%`(REF_I31_NUM_fieldval(v_u31)) -- wf_uN: `%%`(31, v_u31) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_3: - `%`(`REF.NULL_ADDR`_fieldval) + `%`(REF_NULL_ADDR_fieldval) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_4{v_structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_fieldval(v_structaddr)) + `%`(REF_STRUCT_ADDR_fieldval(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_5{v_arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + `%`(REF_ARRAY_ADDR_fieldval(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_6{v_funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_fieldval(v_funcaddr)) + `%`(REF_FUNC_ADDR_fieldval(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_7{v_exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_fieldval(v_exnaddr)) + `%`(REF_EXN_ADDR_fieldval(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_8{v_hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(v_hostaddr)) + `%`(REF_HOST_ADDR_fieldval(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule fieldval_case_9{v_ref : ref}: - `%`(`REF.EXTERN`_fieldval(v_ref)) + `%`(REF_EXTERN_fieldval(v_ref)) -- wf_ref: `%`(v_ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11771,25 +15300,25 @@ relation wf_store: `%`(store) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax state = - | `%;%`(v_store : store, v_frame : frame) + | mk_state(v_store : store, v_frame : frame) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_state: `%`(state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule state_case_0{v_store : store, v_frame : frame}: - `%`(`%;%`_state(v_store, v_frame)) + `%`(mk_state_state(v_store, v_frame)) -- wf_store: `%`(v_store) -- wf_frame: `%`(v_frame) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax config = - | `%;%`(v_state : state, instr_lst : instr*) + | mk_config(v_state : state, instr_lst : instr*) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec relation wf_config: `%`(config) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rule config_case_0{v_state : state, instr_lst : instr*}: - `%`(`%;%`_config(v_state, instr_lst)) + `%`(mk_config_config(v_state, instr_lst)) -- wf_state: `%`(v_state) -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} @@ -11816,127 +15345,136 @@ def $packfield_(v_storagetype : storagetype, v_val : val) : fieldval? def $packfield_{v_val : val}(I32_storagetype, v_val) = ?($fieldval_val(v_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $packfield_{i : uN}(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) = ?(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) - -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) def $packfield_{x0 : storagetype, x1 : val}(x0, x1) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation packfield__is_wf: `%%%`(v_storagetype : storagetype, v_val : val, ret_val : fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule packfield__is_wf_0{v_storagetype : storagetype, v_val : val, ret_val : fieldval}: + `%%%`(v_storagetype, v_val, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- wf_val: `%`(v_val) + -- if (ret_val = !($packfield_(v_storagetype, v_val))) + -- if ($packfield_(v_storagetype, v_val) =/= ?()) + -- wf_fieldval: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_(v_storagetype : storagetype, var_0 : sx?, v_fieldval : fieldval) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(BOT_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(V128_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(V128_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(F64_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(F64_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(F32_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(F32_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(I64_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(I64_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_ref : ref}(I32_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) = ?(`REF.EXTERN`_val(v_ref)) + def $unpackfield_{v_ref : ref}(I32_storagetype, ?(), REF_EXTERN_fieldval(v_ref)) = ?(REF_EXTERN_val(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(BOT_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(V128_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(F64_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(F32_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(I64_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_hostaddr : hostaddr}(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) = ?(`REF.HOST_ADDR`_val(v_hostaddr)) + def $unpackfield_{v_hostaddr : hostaddr}(I32_storagetype, ?(), REF_HOST_ADDR_fieldval(v_hostaddr)) = ?(REF_HOST_ADDR_val(v_hostaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(BOT_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(V128_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(F64_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(F32_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(I64_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_exnaddr : exnaddr}(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) = ?(`REF.EXN_ADDR`_val(v_exnaddr)) + def $unpackfield_{v_exnaddr : exnaddr}(I32_storagetype, ?(), REF_EXN_ADDR_fieldval(v_exnaddr)) = ?(REF_EXN_ADDR_val(v_exnaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(BOT_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(V128_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(F64_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(F32_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(I64_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_funcaddr : funcaddr}(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) = ?(`REF.FUNC_ADDR`_val(v_funcaddr)) + def $unpackfield_{v_funcaddr : funcaddr}(I32_storagetype, ?(), REF_FUNC_ADDR_fieldval(v_funcaddr)) = ?(REF_FUNC_ADDR_val(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(BOT_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(V128_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(F64_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(F32_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(I64_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_arrayaddr : arrayaddr}(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) = ?(`REF.ARRAY_ADDR`_val(v_arrayaddr)) + def $unpackfield_{v_arrayaddr : arrayaddr}(I32_storagetype, ?(), REF_ARRAY_ADDR_fieldval(v_arrayaddr)) = ?(REF_ARRAY_ADDR_val(v_arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(BOT_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(V128_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(F64_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(F32_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(I64_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_structaddr : structaddr}(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) = ?(`REF.STRUCT_ADDR`_val(v_structaddr)) + def $unpackfield_{v_structaddr : structaddr}(I32_storagetype, ?(), REF_STRUCT_ADDR_fieldval(v_structaddr)) = ?(REF_STRUCT_ADDR_val(v_structaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(BOT_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_{null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(V128_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(F64_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(F32_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(I64_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) = ?(`REF.NULL_ADDR`_val) + def $unpackfield_(I32_storagetype, ?(), REF_NULL_ADDR_fieldval) = ?(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(BOT_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(V128_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(F64_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(F32_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(I64_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_u31 : u31}(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) = ?(`REF.I31_NUM`_val(v_u31)) + def $unpackfield_{v_u31 : u31}(I32_storagetype, ?(), REF_I31_NUM_fieldval(v_u31)) = ?(REF_I31_NUM_val(v_u31)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{v_vectype : vectype, var_1 : vec_}(BOT_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec @@ -11967,310 +15505,749 @@ def $unpackfield_(v_storagetype : storagetype, var_0 : sx?, v_fieldval : fieldva def $unpackfield_{v_numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{v_sx : sx, i : uN}(I8_storagetype, ?(v_sx), PACK_fieldval(I8_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, v_sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I8_packtype), 32, v_sx, i)))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $unpackfield_{v_sx : sx, i : uN}(I16_storagetype, ?(v_sx), PACK_fieldval(I16_packtype, i)) = ?(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, v_sx, i)))) - -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, v_sx, i)))) def $unpackfield_{x0 : storagetype, x1 : sx?, x2 : fieldval}(x0, x1, x2) = ?() -- otherwise +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation unpackfield__is_wf: `%%%%`(v_storagetype : storagetype, var_0 : sx?, v_fieldval : fieldval, ret_val : val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule unpackfield__is_wf_0{v_storagetype : storagetype, var_0 : sx?, v_fieldval : fieldval, ret_val : val}: + `%%%%`(v_storagetype, var_0, v_fieldval, ret_val) + -- wf_storagetype: `%`(v_storagetype) + -- wf_fieldval: `%`(v_fieldval) + -- if (ret_val = !($unpackfield_(v_storagetype, var_0, v_fieldval))) + -- if ($unpackfield_(v_storagetype, var_0, v_fieldval) =/= ?()) + -- wf_val: `%`(ret_val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.1-190.86 -def $tagsxa(var_0 : externaddr*) : tagaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:196.1-196.23 - def $tagsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:197.1-197.42 - def $tagsxa{a : nat, xa_lst : externaddr*}([TAG_externaddr(a)] ++ xa_lst) = [a] ++ $tagsxa(xa_lst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:198.1-198.57 - def $tagsxa{v_externaddr : externaddr, xa_lst : externaddr*}([v_externaddr] ++ xa_lst) = $tagsxa(xa_lst) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 +relation fun_tagsxa: `%%`(externaddr*, tagaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_1{a : nat, xa_lst : externaddr*, var_0 : tagaddr*}: + `%%`([TAG_externaddr(a)] ++ xa_lst, [a] ++ var_0) + -- fun_tagsxa: `%%`(xa_lst, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:190.6-190.13 + rule fun_tagsxa_case_2{v_externaddr : externaddr, xa_lst : externaddr*, var_0 : tagaddr*}: + `%%`([v_externaddr] ++ xa_lst, var_0) + -- fun_tagsxa: `%%`(xa_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.1-191.89 -def $globalsxa(var_0 : externaddr*) : globaladdr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:200.1-200.26 - def $globalsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:201.1-201.51 - def $globalsxa{a : nat, xa_lst : externaddr*}([GLOBAL_externaddr(a)] ++ xa_lst) = [a] ++ $globalsxa(xa_lst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:202.1-202.63 - def $globalsxa{v_externaddr : externaddr, xa_lst : externaddr*}([v_externaddr] ++ xa_lst) = $globalsxa(xa_lst) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 +relation fun_globalsxa: `%%`(externaddr*, globaladdr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_1{a : nat, xa_lst : externaddr*, var_0 : globaladdr*}: + `%%`([GLOBAL_externaddr(a)] ++ xa_lst, [a] ++ var_0) + -- fun_globalsxa: `%%`(xa_lst, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:191.6-191.16 + rule fun_globalsxa_case_2{v_externaddr : externaddr, xa_lst : externaddr*, var_0 : globaladdr*}: + `%%`([v_externaddr] ++ xa_lst, var_0) + -- fun_globalsxa: `%%`(xa_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.1-192.86 -def $memsxa(var_0 : externaddr*) : memaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:204.1-204.23 - def $memsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:205.1-205.42 - def $memsxa{a : nat, xa_lst : externaddr*}([MEM_externaddr(a)] ++ xa_lst) = [a] ++ $memsxa(xa_lst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:206.1-206.57 - def $memsxa{v_externaddr : externaddr, xa_lst : externaddr*}([v_externaddr] ++ xa_lst) = $memsxa(xa_lst) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 +relation fun_memsxa: `%%`(externaddr*, memaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_1{a : nat, xa_lst : externaddr*, var_0 : memaddr*}: + `%%`([MEM_externaddr(a)] ++ xa_lst, [a] ++ var_0) + -- fun_memsxa: `%%`(xa_lst, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:192.6-192.13 + rule fun_memsxa_case_2{v_externaddr : externaddr, xa_lst : externaddr*, var_0 : memaddr*}: + `%%`([v_externaddr] ++ xa_lst, var_0) + -- fun_memsxa: `%%`(xa_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.1-193.88 -def $tablesxa(var_0 : externaddr*) : tableaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:208.1-208.25 - def $tablesxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:209.1-209.48 - def $tablesxa{a : nat, xa_lst : externaddr*}([TABLE_externaddr(a)] ++ xa_lst) = [a] ++ $tablesxa(xa_lst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:210.1-210.61 - def $tablesxa{v_externaddr : externaddr, xa_lst : externaddr*}([v_externaddr] ++ xa_lst) = $tablesxa(xa_lst) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 +relation fun_tablesxa: `%%`(externaddr*, tableaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_1{a : nat, xa_lst : externaddr*, var_0 : tableaddr*}: + `%%`([TABLE_externaddr(a)] ++ xa_lst, [a] ++ var_0) + -- fun_tablesxa: `%%`(xa_lst, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:193.6-193.15 + rule fun_tablesxa_case_2{v_externaddr : externaddr, xa_lst : externaddr*, var_0 : tableaddr*}: + `%%`([v_externaddr] ++ xa_lst, var_0) + -- fun_tablesxa: `%%`(xa_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.1-194.87 -def $funcsxa(var_0 : externaddr*) : funcaddr* - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:212.1-212.24 - def $funcsxa([]) = [] - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:213.1-213.45 - def $funcsxa{a : nat, xa_lst : externaddr*}([FUNC_externaddr(a)] ++ xa_lst) = [a] ++ $funcsxa(xa_lst) - ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:214.1-214.59 - def $funcsxa{v_externaddr : externaddr, xa_lst : externaddr*}([v_externaddr] ++ xa_lst) = $funcsxa(xa_lst) +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 +relation fun_funcsxa: `%%`(externaddr*, funcaddr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_1{a : nat, xa_lst : externaddr*, var_0 : funcaddr*}: + `%%`([FUNC_externaddr(a)] ++ xa_lst, [a] ++ var_0) + -- fun_funcsxa: `%%`(xa_lst, var_0) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:194.6-194.14 + rule fun_funcsxa_case_2{v_externaddr : externaddr, xa_lst : externaddr*, var_0 : funcaddr*}: + `%%`([v_externaddr] ++ xa_lst, var_0) + -- fun_funcsxa: `%%`(xa_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fun_store(v_state : state) : store ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_store{s : store, f : frame}(`%;%`_state(s, f)) = s + def $fun_store{s : store, f : frame}(mk_state_state(s, f)) = s + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation store_is_wf: `%%`(v_state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule store_is_wf_0{v_state : state, ret_val : store}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_store(v_state)) + -- wf_store: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fun_frame(v_state : state) : frame ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_frame{s : store, f : frame}(`%;%`_state(s, f)) = f + def $fun_frame{s : store, f : frame}(mk_state_state(s, f)) = f + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation frame_is_wf: `%%`(v_state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule frame_is_wf_0{v_state : state, ret_val : frame}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_frame(v_state)) + -- wf_frame: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fun_tagaddr(v_state : state) : tagaddr* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_tagaddr{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame.TAGS_moduleinst + def $fun_tagaddr{s : store, f : frame}(mk_state_state(s, f)) = f.MODULE_frame.TAGS_moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fun_moduleinst(v_state : state) : moduleinst ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_moduleinst{s : store, f : frame}(`%;%`_state(s, f)) = f.MODULE_frame + def $fun_moduleinst{s : store, f : frame}(mk_state_state(s, f)) = f.MODULE_frame + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation moduleinst_is_wf: `%%`(v_state : state, ret_val : moduleinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule moduleinst_is_wf_0{v_state : state, ret_val : moduleinst}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_moduleinst(v_state)) + -- wf_moduleinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec def $fun_taginst(v_state : state) : taginst* ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_taginst{s : store, f : frame}(`%;%`_state(s, f)) = s.TAGS_store + def $fun_taginst{s : store, f : frame}(mk_state_state(s, f)) = s.TAGS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation taginst_is_wf: `%%`(v_state : state, ret_val : taginst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule taginst_is_wf_0{v_state : state, ret_val : taginst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_taginst(v_state)) + -- (wf_taginst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_globalinst(v_state : state) : globalinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_globalinst{s : store, f : frame}(mk_state_state(s, f)) = s.GLOBALS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation globalinst_is_wf: `%%`(v_state : state, ret_val : globalinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule globalinst_is_wf_0{v_state : state, ret_val : globalinst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_globalinst(v_state)) + -- (wf_globalinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_meminst(v_state : state) : meminst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_meminst{s : store, f : frame}(mk_state_state(s, f)) = s.MEMS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation meminst_is_wf: `%%`(v_state : state, ret_val : meminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule meminst_is_wf_0{v_state : state, ret_val : meminst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_meminst(v_state)) + -- (wf_meminst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_tableinst(v_state : state) : tableinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_tableinst{s : store, f : frame}(mk_state_state(s, f)) = s.TABLES_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tableinst_is_wf: `%%`(v_state : state, ret_val : tableinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tableinst_is_wf_0{v_state : state, ret_val : tableinst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_tableinst(v_state)) + -- (wf_tableinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_funcinst(v_state : state) : funcinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_funcinst{s : store, f : frame}(mk_state_state(s, f)) = s.FUNCS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation funcinst_is_wf: `%%`(v_state : state, ret_val : funcinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule funcinst_is_wf_0{v_state : state, ret_val : funcinst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_funcinst(v_state)) + -- (wf_funcinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_datainst(v_state : state) : datainst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_datainst{s : store, f : frame}(mk_state_state(s, f)) = s.DATAS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation datainst_is_wf: `%%`(v_state : state, ret_val : datainst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule datainst_is_wf_0{v_state : state, ret_val : datainst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_datainst(v_state)) + -- (wf_datainst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_eleminst(v_state : state) : eleminst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_eleminst{s : store, f : frame}(mk_state_state(s, f)) = s.ELEMS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation eleminst_is_wf: `%%`(v_state : state, ret_val : eleminst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule eleminst_is_wf_0{v_state : state, ret_val : eleminst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_eleminst(v_state)) + -- (wf_eleminst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_structinst(v_state : state) : structinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_structinst{s : store, f : frame}(mk_state_state(s, f)) = s.STRUCTS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation structinst_is_wf: `%%`(v_state : state, ret_val : structinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule structinst_is_wf_0{v_state : state, ret_val : structinst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_structinst(v_state)) + -- (wf_structinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_arrayinst(v_state : state) : arrayinst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_arrayinst{s : store, f : frame}(mk_state_state(s, f)) = s.ARRAYS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation arrayinst_is_wf: `%%`(v_state : state, ret_val : arrayinst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule arrayinst_is_wf_0{v_state : state, ret_val : arrayinst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_arrayinst(v_state)) + -- (wf_arrayinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_exninst(v_state : state) : exninst* + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_exninst{s : store, f : frame}(mk_state_state(s, f)) = s.EXNS_store + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation exninst_is_wf: `%%`(v_state : state, ret_val : exninst*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule exninst_is_wf_0{v_state : state, ret_val : exninst*}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fun_exninst(v_state)) + -- (wf_exninst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fof(v_state : state) : frame + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fof{z : state}(z) = $fun_frame(z) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fof_is_wf: `%%`(v_state : state, ret_val : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fof_is_wf_0{v_state : state, ret_val : frame}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $fof(v_state)) + -- wf_frame: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_type(v_state : state, v_typeidx : typeidx) : deftype + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_type{z : state, x : uN}(z, x) = $fof(z).MODULE_frame.TYPES_moduleinst[$proj_uN_0(x).0] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $sof(v_state : state) : store + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $sof{z : state}(z) = $fun_store(z) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation sof_is_wf: `%%`(v_state : state, ret_val : store) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule sof_is_wf_0{v_state : state, ret_val : store}: + `%%`(v_state, ret_val) + -- wf_state: `%`(v_state) + -- if (ret_val = $sof(v_state)) + -- wf_store: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_tag(v_state : state, v_tagidx : tagidx) : taginst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation tag_is_wf: `%%%`(v_state : state, v_tagidx : tagidx, ret_val : taginst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule tag_is_wf_0{v_state : state, v_tagidx : tagidx, ret_val : taginst}: + `%%%`(v_state, v_tagidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_tagidx) + -- if (ret_val = $fun_tag(v_state, v_tagidx)) + -- wf_taginst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_global(v_state : state, v_globalidx : globalidx) : globalinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation global_is_wf: `%%%`(v_state : state, v_globalidx : globalidx, ret_val : globalinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule global_is_wf_0{v_state : state, v_globalidx : globalidx, ret_val : globalinst}: + `%%%`(v_state, v_globalidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_globalidx) + -- if (ret_val = $fun_global(v_state, v_globalidx)) + -- wf_globalinst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_mem(v_state : state, v_memidx : memidx) : meminst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation mem_is_wf: `%%%`(v_state : state, v_memidx : memidx, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule mem_is_wf_0{v_state : state, v_memidx : memidx, ret_val : meminst}: + `%%%`(v_state, v_memidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_memidx) + -- if (ret_val = $fun_mem(v_state, v_memidx)) + -- wf_meminst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_table(v_state : state, v_tableidx : tableidx) : tableinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation table_is_wf: `%%%`(v_state : state, v_tableidx : tableidx, ret_val : tableinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule table_is_wf_0{v_state : state, v_tableidx : tableidx, ret_val : tableinst}: + `%%%`(v_state, v_tableidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_tableidx) + -- if (ret_val = $fun_table(v_state, v_tableidx)) + -- wf_tableinst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_func(v_state : state, v_funcidx : funcidx) : funcinst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation func_is_wf: `%%%`(v_state : state, v_funcidx : funcidx, ret_val : funcinst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule func_is_wf_0{v_state : state, v_funcidx : funcidx, ret_val : funcinst}: + `%%%`(v_state, v_funcidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_funcidx) + -- if (ret_val = $fun_func(v_state, v_funcidx)) + -- wf_funcinst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_data(v_state : state, v_dataidx : dataidx) : datainst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation data_is_wf: `%%%`(v_state : state, v_dataidx : dataidx, ret_val : datainst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule data_is_wf_0{v_state : state, v_dataidx : dataidx, ret_val : datainst}: + `%%%`(v_state, v_dataidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_dataidx) + -- if (ret_val = $fun_data(v_state, v_dataidx)) + -- wf_datainst: `%`(ret_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +def $fun_elem(v_state : state, v_tableidx : tableidx) : eleminst + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + def $fun_elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_globalinst(v_state : state) : globalinst* +relation elem_is_wf: `%%%`(v_state : state, v_tableidx : tableidx, ret_val : eleminst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_globalinst{s : store, f : frame}(`%;%`_state(s, f)) = s.GLOBALS_store + rule elem_is_wf_0{v_state : state, v_tableidx : tableidx, ret_val : eleminst}: + `%%%`(v_state, v_tableidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_tableidx) + -- if (ret_val = $fun_elem(v_state, v_tableidx)) + -- wf_eleminst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_meminst(v_state : state) : meminst* +def $fun_local(v_state : state, v_localidx : localidx) : val? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_meminst{s : store, f : frame}(`%;%`_state(s, f)) = s.MEMS_store + def $fun_local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_tableinst(v_state : state) : tableinst* +relation local_is_wf: `%%%`(v_state : state, v_localidx : localidx, ret_val : val?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_tableinst{s : store, f : frame}(`%;%`_state(s, f)) = s.TABLES_store + rule local_is_wf_0{v_state : state, v_localidx : localidx, ret_val : val?}: + `%%%`(v_state, v_localidx, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_localidx) + -- if (ret_val = $fun_local(v_state, v_localidx)) + -- (wf_val: `%`(ret_val))?{ret_val <- ret_val} ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_funcinst(v_state : state) : funcinst* +def $with_local(v_state : state, v_localidx : localidx, v_val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_funcinst{s : store, f : frame}(`%;%`_state(s, f)) = s.FUNCS_store + def $with_local{z : state, x : uN, v : val}(z, x, v) = mk_state_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_datainst(v_state : state) : datainst* +relation with_local_is_wf: `%%%%`(v_state : state, v_localidx : localidx, v_val : val, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_datainst{s : store, f : frame}(`%;%`_state(s, f)) = s.DATAS_store + rule with_local_is_wf_0{v_state : state, v_localidx : localidx, v_val : val, ret_val : state}: + `%%%%`(v_state, v_localidx, v_val, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_localidx) + -- wf_val: `%`(v_val) + -- if (ret_val = $with_local(v_state, v_localidx, v_val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_eleminst(v_state : state) : eleminst* +def $with_global(v_state : state, v_globalidx : globalidx, v_val : val) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_eleminst{s : store, f : frame}(`%;%`_state(s, f)) = s.ELEMS_store + def $with_global{z : state, x : uN, v : val}(z, x, v) = mk_state_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_structinst(v_state : state) : structinst* +relation with_global_is_wf: `%%%%`(v_state : state, v_globalidx : globalidx, v_val : val, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_structinst{s : store, f : frame}(`%;%`_state(s, f)) = s.STRUCTS_store + rule with_global_is_wf_0{v_state : state, v_globalidx : globalidx, v_val : val, ret_val : state}: + `%%%%`(v_state, v_globalidx, v_val, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_globalidx) + -- wf_val: `%`(v_val) + -- if (ret_val = $with_global(v_state, v_globalidx, v_val)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_arrayinst(v_state : state) : arrayinst* +def $with_table(v_state : state, v_tableidx : tableidx, nat : nat, v_ref : ref) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_arrayinst{s : store, f : frame}(`%;%`_state(s, f)) = s.ARRAYS_store + def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = mk_state_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_exninst(v_state : state) : exninst* +relation with_table_is_wf: `%%%%%`(v_state : state, v_tableidx : tableidx, nat : nat, v_ref : ref, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_exninst{s : store, f : frame}(`%;%`_state(s, f)) = s.EXNS_store + rule with_table_is_wf_0{v_state : state, v_tableidx : tableidx, nat : nat, v_ref : ref, ret_val : state}: + `%%%%%`(v_state, v_tableidx, nat, v_ref, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_tableidx) + -- wf_ref: `%`(v_ref) + -- if (ret_val = $with_table(v_state, v_tableidx, nat, v_ref)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fof(v_state : state) : frame +def $with_tableinst(v_state : state, v_tableidx : tableidx, v_tableinst : tableinst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fof{z : state}(z) = $fun_frame(z) + def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = mk_state_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_type(v_state : state, v_typeidx : typeidx) : deftype +relation with_tableinst_is_wf: `%%%%`(v_state : state, v_tableidx : tableidx, v_tableinst : tableinst, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_type{z : state, x : uN}(z, x) = $fof(z).MODULE_frame.TYPES_moduleinst[$proj_uN_0(x).0] + rule with_tableinst_is_wf_0{v_state : state, v_tableidx : tableidx, v_tableinst : tableinst, ret_val : state}: + `%%%%`(v_state, v_tableidx, v_tableinst, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_tableidx) + -- wf_tableinst: `%`(v_tableinst) + -- if (ret_val = $with_tableinst(v_state, v_tableidx, v_tableinst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $sof(v_state : state) : store +def $with_mem(v_state : state, v_memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $sof{z : state}(z) = $fun_store(z) + def $with_mem{z : state, x : uN, i : nat, j : nat, b_lst : byte*}(z, x, i, j, b_lst) = mk_state_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_tag(v_state : state, v_tagidx : tagidx) : taginst +relation with_mem_is_wf: `%%%%%%`(v_state : state, v_memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_tag{z : state, x : uN}(z, x) = $sof(z).TAGS_store[$fof(z).MODULE_frame.TAGS_moduleinst[$proj_uN_0(x).0]] + rule with_mem_is_wf_0{v_state : state, v_memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*, ret_val : state}: + `%%%%%%`(v_state, v_memidx, nat, nat_0, var_0, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_memidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_mem(v_state, v_memidx, nat, nat_0, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_global(v_state : state, v_globalidx : globalidx) : globalinst +def $with_meminst(v_state : state, v_memidx : memidx, v_meminst : meminst) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_global{z : state, x : uN}(z, x) = $sof(z).GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]] + def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = mk_state_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_mem(v_state : state, v_memidx : memidx) : meminst +relation with_meminst_is_wf: `%%%%`(v_state : state, v_memidx : memidx, v_meminst : meminst, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_mem{z : state, x : uN}(z, x) = $sof(z).MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] + rule with_meminst_is_wf_0{v_state : state, v_memidx : memidx, v_meminst : meminst, ret_val : state}: + `%%%%`(v_state, v_memidx, v_meminst, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_memidx) + -- wf_meminst: `%`(v_meminst) + -- if (ret_val = $with_meminst(v_state, v_memidx, v_meminst)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_table(v_state : state, v_tableidx : tableidx) : tableinst +def $with_elem(v_state : state, v_elemidx : elemidx, var_0 : ref*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_table{z : state, x : uN}(z, x) = $sof(z).TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] + def $with_elem{z : state, x : uN, r_lst : ref*}(z, x, r_lst) = mk_state_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_func(v_state : state, v_funcidx : funcidx) : funcinst +relation with_elem_is_wf: `%%%%`(v_state : state, v_elemidx : elemidx, var_0 : ref*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_func{z : state, x : uN}(z, x) = $sof(z).FUNCS_store[$fof(z).MODULE_frame.FUNCS_moduleinst[$proj_uN_0(x).0]] + rule with_elem_is_wf_0{v_state : state, v_elemidx : elemidx, var_0 : ref*, ret_val : state}: + `%%%%`(v_state, v_elemidx, var_0, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_elemidx) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_elem(v_state, v_elemidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_data(v_state : state, v_dataidx : dataidx) : datainst +def $with_data(v_state : state, v_dataidx : dataidx, var_0 : byte*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_data{z : state, x : uN}(z, x) = $sof(z).DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]] + def $with_data{z : state, x : uN, b_lst : byte*}(z, x, b_lst) = mk_state_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_elem(v_state : state, v_tableidx : tableidx) : eleminst +relation with_data_is_wf: `%%%%`(v_state : state, v_dataidx : dataidx, var_0 : byte*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_elem{z : state, x : uN}(z, x) = $sof(z).ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]] + rule with_data_is_wf_0{v_state : state, v_dataidx : dataidx, var_0 : byte*, ret_val : state}: + `%%%%`(v_state, v_dataidx, var_0, ret_val) + -- wf_state: `%`(v_state) + -- wf_uN: `%%`(32, v_dataidx) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $with_data(v_state, v_dataidx, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $fun_local(v_state : state, v_localidx : localidx) : val? +def $with_struct(v_state : state, v_structaddr : structaddr, nat : nat, v_fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $fun_local{z : state, x : uN}(z, x) = $fof(z).LOCALS_frame[$proj_uN_0(x).0] + def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = mk_state_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_local(v_state : state, v_localidx : localidx, v_val : val) : state +relation with_struct_is_wf: `%%%%%`(v_state : state, v_structaddr : structaddr, nat : nat, v_fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_local{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)]) - -- wf_state: `%`(`%;%`_state($sof(z), $fof(z)[LOCALS_frame[$proj_uN_0(x).0] = ?(v)])) + rule with_struct_is_wf_0{v_state : state, v_structaddr : structaddr, nat : nat, v_fieldval : fieldval, ret_val : state}: + `%%%%%`(v_state, v_structaddr, nat, v_fieldval, ret_val) + -- wf_state: `%`(v_state) + -- wf_fieldval: `%`(v_fieldval) + -- if (ret_val = $with_struct(v_state, v_structaddr, nat, v_fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_global(v_state : state, v_globalidx : globalidx, v_val : val) : state +def $with_array(v_state : state, v_arrayaddr : arrayaddr, nat : nat, v_fieldval : fieldval) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_global{z : state, x : uN, v : val}(z, x, v) = `%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[GLOBALS_store[$fof(z).MODULE_frame.GLOBALS_moduleinst[$proj_uN_0(x).0]].VALUE_globalinst = v], $fof(z))) + def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = mk_state_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_table(v_state : state, v_tableidx : tableidx, nat : nat, v_ref : ref) : state +relation with_array_is_wf: `%%%%%`(v_state : state, v_arrayaddr : arrayaddr, nat : nat, v_fieldval : fieldval, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_table{z : state, x : uN, i : nat, r : ref}(z, x, i, r) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]].REFS_tableinst[i] = r], $fof(z))) + rule with_array_is_wf_0{v_state : state, v_arrayaddr : arrayaddr, nat : nat, v_fieldval : fieldval, ret_val : state}: + `%%%%%`(v_state, v_arrayaddr, nat, v_fieldval, ret_val) + -- wf_state: `%`(v_state) + -- wf_fieldval: `%`(v_fieldval) + -- if (ret_val = $with_array(v_state, v_arrayaddr, nat, v_fieldval)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_tableinst(v_state : state, v_tableidx : tableidx, v_tableinst : tableinst) : state +def $add_structinst(v_state : state, var_0 : structinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_tableinst{z : state, x : uN, ti : tableinst}(z, x, ti) = `%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[TABLES_store[$fof(z).MODULE_frame.TABLES_moduleinst[$proj_uN_0(x).0]] = ti], $fof(z))) + def $add_structinst{z : state, si_lst : structinst*}(z, si_lst) = mk_state_state($sof(z)[STRUCTS_store =++ si_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_mem(v_state : state, v_memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*) : state +relation add_structinst_is_wf: `%%%`(v_state : state, var_0 : structinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_mem{z : state, x : uN, i : nat, j : nat, b_lst : byte*}(z, x, i, j, b_lst) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]].BYTES_meminst[i : j] = b_lst], $fof(z))) + rule add_structinst_is_wf_0{v_state : state, var_0 : structinst*, ret_val : state}: + `%%%`(v_state, var_0, ret_val) + -- wf_state: `%`(v_state) + -- (wf_structinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_structinst(v_state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_meminst(v_state : state, v_memidx : memidx, v_meminst : meminst) : state +def $add_arrayinst(v_state : state, var_0 : arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_meminst{z : state, x : uN, mi : meminst}(z, x, mi) = `%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[MEMS_store[$fof(z).MODULE_frame.MEMS_moduleinst[$proj_uN_0(x).0]] = mi], $fof(z))) + def $add_arrayinst{z : state, ai_lst : arrayinst*}(z, ai_lst) = mk_state_state($sof(z)[ARRAYS_store =++ ai_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_elem(v_state : state, v_elemidx : elemidx, var_0 : ref*) : state +relation add_arrayinst_is_wf: `%%%`(v_state : state, var_0 : arrayinst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_elem{z : state, x : uN, r_lst : ref*}(z, x, r_lst) = `%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ELEMS_store[$fof(z).MODULE_frame.ELEMS_moduleinst[$proj_uN_0(x).0]].REFS_eleminst = r_lst], $fof(z))) + rule add_arrayinst_is_wf_0{v_state : state, var_0 : arrayinst*, ret_val : state}: + `%%%`(v_state, var_0, ret_val) + -- wf_state: `%`(v_state) + -- (wf_arrayinst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_arrayinst(v_state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_data(v_state : state, v_dataidx : dataidx, var_0 : byte*) : state +def $add_exninst(v_state : state, var_0 : exninst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_data{z : state, x : uN, b_lst : byte*}(z, x, b_lst) = `%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[DATAS_store[$fof(z).MODULE_frame.DATAS_moduleinst[$proj_uN_0(x).0]].BYTES_datainst = b_lst], $fof(z))) + def $add_exninst{z : state, exn_lst : exninst*}(z, exn_lst) = mk_state_state($sof(z)[EXNS_store =++ exn_lst], $fof(z)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(v_state : state, v_structaddr : structaddr, nat : nat, v_fieldval : fieldval) : state +relation add_exninst_is_wf: `%%%`(v_state : state, var_0 : exninst*, ret_val : state) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_struct{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store[a].FIELDS_structinst[i] = fv], $fof(z))) + rule add_exninst_is_wf_0{v_state : state, var_0 : exninst*, ret_val : state}: + `%%%`(v_state, var_0, ret_val) + -- wf_state: `%`(v_state) + -- (wf_exninst: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $add_exninst(v_state, var_0)) + -- wf_state: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_array(v_state : state, v_arrayaddr : arrayaddr, nat : nat, v_fieldval : fieldval) : state +relation fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $with_array{z : state, a : nat, i : nat, fv : fieldval}(z, a, i, fv) = `%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store[a].FIELDS_arrayinst[i] = fv], $fof(z))) + rule fun_growtable_case_0{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%`(v_tableinst, v_n, r) + -- let{at : addrtype, i : u64, j_opt : u64?, rt : reftype, r'_lst : ref*} {TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS r'_lst} = v_tableinst + -- if (tableinst' = {TYPE mk_tabletype_tabletype(at, mk_limits_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) + -- if ($proj_uN_0(i').0 = (|r'_lst| + v_n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j_3).0))?{j_3 <- j_opt} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS r'_lst}) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_structinst(v_state : state, var_0 : structinst*) : state +relation fun_growtable: `%%%%`(tableinst, nat, ref, tableinst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_structinst{z : state, si_lst : structinst*}(z, si_lst) = `%;%`_state($sof(z)[STRUCTS_store =++ si_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[STRUCTS_store =++ si_lst], $fof(z))) + rule fun_growtable_case_0{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, i' : uN}: + `%%%%`(v_tableinst, v_n, r, ?(tableinst')) + -- let{at : addrtype, i : u64, j_opt : u64?, rt : reftype, r'_lst : ref*} {TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS r'_lst} = v_tableinst + -- if (tableinst' = {TYPE mk_tabletype_tabletype(at, mk_limits_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) + -- if ($proj_uN_0(i').0 = (|r'_lst| + v_n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j_3).0))?{j_3 <- j_opt} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS r'_lst}) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_arrayinst(v_state : state, var_0 : arrayinst*) : state ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_arrayinst{z : state, ai_lst : arrayinst*}(z, ai_lst) = `%;%`_state($sof(z)[ARRAYS_store =++ ai_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[ARRAYS_store =++ ai_lst], $fof(z))) + rule fun_growtable_case_1{x0 : tableinst, x1 : nat, x2 : ref}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_growtable_before_fun_growtable_case_1: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_exninst(v_state : state, var_0 : exninst*) : state +relation growtable_is_wf: `%%%%`(v_tableinst : tableinst, nat : nat, v_ref : ref, ret_val : tableinst) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $add_exninst{z : state, exn_lst : exninst*}(z, exn_lst) = `%;%`_state($sof(z)[EXNS_store =++ exn_lst], $fof(z)) - -- wf_state: `%`(`%;%`_state($sof(z)[EXNS_store =++ exn_lst], $fof(z))) + rule growtable_is_wf_0{v_tableinst : tableinst, nat : nat, v_ref : ref, ret_val : tableinst, var_0 : tableinst?}: + `%%%%`(v_tableinst, nat, v_ref, ret_val) + -- wf_tableinst: `%`(v_tableinst) + -- wf_ref: `%`(v_ref) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(ret_val) + -- fun_growtable: `%%%%`(v_tableinst, nat, v_ref, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(v_tableinst : tableinst, nat : nat, v_ref : ref) : tableinst? +relation fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, i' : uN}(v_tableinst, v_n, r) = ?(tableinst') - -- let{at : addrtype, i : u64, j_opt : u64?, rt : reftype, r'_lst : ref*} {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS r'_lst} = v_tableinst - -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) - -- if ($proj_uN_0(i').0 = (|r'_lst| + v_n)) - -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#3).0))?{j#3 <- j_opt} - -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) - -- wf_tableinst: `%`(tableinst') - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS r'_lst}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j_opt), rt), REFS r'_lst ++ r^v_n{}}) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise + rule fun_growmem_case_0{v_meminst : meminst, v_n : nat, meminst' : meminst, i' : uN}: + `%%`(v_meminst, v_n) + -- let{at : addrtype, i : u64, j_opt : u64?, b_lst : byte*} {TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES b_lst} = v_meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, mk_limits_limits(i', j_opt)), BYTES b_lst ++ mk_byte_byte(0)^(v_n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b_lst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (v_n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j_8).0))?{j_8 <- j_opt} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES b_lst}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(i', j_opt)), BYTES b_lst ++ mk_byte_byte(0)^(v_n * (64 * $Ki)){}}) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(v_meminst : meminst, nat : nat) : meminst? +relation fun_growmem: `%%%`(meminst, nat, meminst?) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{v_meminst : meminst, v_n : nat, meminst' : meminst, i' : uN}(v_meminst, v_n) = ?(meminst') - -- let{at : addrtype, i : u64, j_opt : u64?, b_lst : byte*} {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES b_lst} = v_meminst - -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j_opt)), BYTES b_lst ++ `%`_byte(0)^(v_n * (64 * $Ki)){}}) + rule fun_growmem_case_0{v_meminst : meminst, v_n : nat, meminst' : meminst, i' : uN}: + `%%%`(v_meminst, v_n, ?(meminst')) + -- let{at : addrtype, i : u64, j_opt : u64?, b_lst : byte*} {TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES b_lst} = v_meminst + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, mk_limits_limits(i', j_opt)), BYTES b_lst ++ mk_byte_byte(0)^(v_n * (64 * $Ki)){}}) -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b_lst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (v_n : nat <:> rat))) - -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#8).0))?{j#8 <- j_opt} + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j_8).0))?{j_8 <- j_opt} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - -- wf_meminst: `%`(meminst') - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES b_lst}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j_opt)), BYTES b_lst ++ `%`_byte(0)^(v_n * (64 * $Ki)){}}) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES b_lst}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(i', j_opt)), BYTES b_lst ++ mk_byte_byte(0)^(v_n * (64 * $Ki)){}}) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_1{x0 : meminst, x1 : nat}: + `%%%`(x0, x1, ?()) + -- ~ fun_growmem_before_fun_growmem_case_1: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation growmem_is_wf: `%%%`(v_meminst : meminst, nat : nat, ret_val : meminst) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule growmem_is_wf_0{v_meminst : meminst, nat : nat, ret_val : meminst, var_0 : meminst?}: + `%%%`(v_meminst, nat, ret_val) + -- wf_meminst: `%`(v_meminst) + -- if (ret_val = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(ret_val) + -- fun_growmem: `%%%`(v_meminst, nat, var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -12295,72 +16272,72 @@ rec { relation Ref_ok: `%|-%:%`(store, ref, reftype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:35.1-36.36 rule null{s : store}: - `%|-%:%`(s, `REF.NULL_ADDR`_ref, REF_reftype(?(NULL_null), BOT_heaptype)) + `%|-%:%`(s, REF_NULL_ADDR_ref, REF_reftype(?(NULL_null), BOT_heaptype)) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_ref: `%`(REF_NULL_ADDR_ref) -- wf_reftype: `%`(REF_reftype(?(NULL_null), BOT_heaptype)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:38.1-39.31 rule i31{s : store, i : u31}: - `%|-%:%`(s, `REF.I31_NUM`_ref(i), REF_reftype(?(), I31_heaptype)) + `%|-%:%`(s, REF_I31_NUM_ref(i), REF_reftype(?(), I31_heaptype)) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.I31_NUM`_ref(i)) + -- wf_ref: `%`(REF_I31_NUM_ref(i)) -- wf_reftype: `%`(REF_reftype(?(), I31_heaptype)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:41.1-43.31 rule struct{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.STRUCT_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.STRUCTS_store|) + `%|-%:%`(s, REF_STRUCT_ADDR_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) + -- if (a < |s.STRUCTS_store|) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) + -- wf_ref: `%`(REF_STRUCT_ADDR_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 rule array{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.ARRAY_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.ARRAYS_store|) + `%|-%:%`(s, REF_ARRAY_ADDR_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) + -- if (a < |s.ARRAYS_store|) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) + -- wf_ref: `%`(REF_ARRAY_ADDR_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 rule func{s : store, a : addr, dt : deftype}: - `%|-%:%`(s, `REF.FUNC_ADDR`_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.FUNCS_store|) + `%|-%:%`(s, REF_FUNC_ADDR_ref(a), REF_reftype(?(), $heaptype_deftype(dt))) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) + -- wf_ref: `%`(REF_FUNC_ADDR_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 rule exn{s : store, a : addr, exn : exninst}: - `%|-%:%`(s, `REF.EXN_ADDR`_ref(a), REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) + `%|-%:%`(s, REF_EXN_ADDR_ref(a), REF_reftype(?(), EXN_heaptype)) -- if (s.EXNS_store[a] = exn) + -- if (a < |s.EXNS_store|) -- wf_store: `%`(s) -- wf_exninst: `%`(exn) - -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) + -- wf_ref: `%`(REF_EXN_ADDR_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.33 rule host{s : store, a : addr}: - `%|-%:%`(s, `REF.HOST_ADDR`_ref(a), REF_reftype(?(), ANY_heaptype)) + `%|-%:%`(s, REF_HOST_ADDR_ref(a), REF_reftype(?(), ANY_heaptype)) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.HOST_ADDR`_ref(a)) + -- wf_ref: `%`(REF_HOST_ADDR_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), ANY_heaptype)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:60.1-63.30 rule extern{s : store, v_ref : ref}: - `%|-%:%`(s, `REF.EXTERN`_ref(v_ref), REF_reftype(?(), EXTERN_heaptype)) + `%|-%:%`(s, REF_EXTERN_ref(v_ref), REF_reftype(?(), EXTERN_heaptype)) -- Ref_ok: `%|-%:%`(s, v_ref, REF_reftype(?(), ANY_heaptype)) - -- if (v_ref =/= `REF.NULL_ADDR`_ref) + -- if (v_ref =/= REF_NULL_ADDR_ref) -- wf_store: `%`(s) - -- wf_ref: `%`(`REF.EXTERN`_ref(v_ref)) + -- wf_ref: `%`(REF_EXTERN_ref(v_ref)) -- wf_reftype: `%`(REF_reftype(?(), EXTERN_heaptype)) -- wf_reftype: `%`(REF_reftype(?(), ANY_heaptype)) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_ref: `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:65.1-69.34 rule sub{s : store, v_ref : ref, rt : reftype, rt' : reftype}: @@ -12432,40 +16409,40 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:106.1-108.28 rule tag{s : store, a : addr, v_taginst : taginst}: `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(v_taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = v_taginst) + -- if (a < |s.TAGS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(v_taginst.TYPE_taginst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:110.1-112.34 rule global{s : store, a : addr, v_globalinst : globalinst}: `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(v_globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = v_globalinst) + -- if (a < |s.GLOBALS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(v_globalinst.TYPE_globalinst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:114.1-116.28 rule mem{s : store, a : addr, v_meminst : meminst}: `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(v_meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = v_meminst) + -- if (a < |s.MEMS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(v_meminst.TYPE_meminst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:118.1-120.32 rule table{s : store, a : addr, v_tableinst : tableinst}: `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(v_tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = v_tableinst) + -- if (a < |s.TABLES_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(v_tableinst.TYPE_tableinst)) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:122.1-124.30 rule func{s : store, a : addr, v_funcinst : funcinst}: `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(v_funcinst.TYPE_funcinst))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = v_funcinst) + -- if (a < |s.FUNCS_store|) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(v_funcinst.TYPE_funcinst))) @@ -12482,41 +16459,106 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) } ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_valtype(v_moduleinst : moduleinst, v_valtype : valtype) : valtype +relation fun_inst_valtype: `%%%`(moduleinst, valtype, valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_valtype_case_0{v_moduleinst : moduleinst, t : valtype, var_0 : valtype}: + `%%%`(v_moduleinst, t, var_0) + -- fun_subst_all_valtype: `%%%`(t, (iter_val_3 : deftype <: typeuse)*{iter_val_3 <- v_moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_valtype_is_wf: `%%%`(v_moduleinst : moduleinst, v_valtype : valtype, ret_val : valtype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_valtype_is_wf_0{v_moduleinst : moduleinst, v_valtype : valtype, ret_val : valtype, var_0 : valtype}: + `%%%`(v_moduleinst, v_valtype, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_valtype: `%`(v_valtype) + -- if (ret_val = var_0) + -- wf_valtype: `%`(ret_val) + -- fun_inst_valtype: `%%%`(v_moduleinst, v_valtype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_reftype: `%%%`(moduleinst, reftype, reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule fun_inst_reftype_case_0{v_moduleinst : moduleinst, rt : reftype, var_0 : reftype}: + `%%%`(v_moduleinst, rt, var_0) + -- fun_subst_all_reftype: `%%%`(rt, (iter_val_4 : deftype <: typeuse)*{iter_val_4 <- v_moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_reftype_is_wf: `%%%`(v_moduleinst : moduleinst, v_reftype : reftype, ret_val : reftype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_reftype_is_wf_0{v_moduleinst : moduleinst, v_reftype : reftype, ret_val : reftype, var_0 : reftype}: + `%%%`(v_moduleinst, v_reftype, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_reftype: `%`(v_reftype) + -- if (ret_val = var_0) + -- wf_reftype: `%`(ret_val) + -- fun_inst_reftype: `%%%`(v_moduleinst, v_reftype, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation fun_inst_globaltype: `%%%`(moduleinst, globaltype, globaltype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_valtype{v_moduleinst : moduleinst, t : valtype}(v_moduleinst, t) = $subst_all_valtype(t, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- v_moduleinst.TYPES_moduleinst}) + rule fun_inst_globaltype_case_0{v_moduleinst : moduleinst, gt : globaltype, var_0 : globaltype}: + `%%%`(v_moduleinst, gt, var_0) + -- fun_subst_all_globaltype: `%%%`(gt, (iter_val_5 : deftype <: typeuse)*{iter_val_5 <- v_moduleinst.TYPES_moduleinst}, var_0) + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +relation inst_globaltype_is_wf: `%%%`(v_moduleinst : moduleinst, v_globaltype : globaltype, ret_val : globaltype) + ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec + rule inst_globaltype_is_wf_0{v_moduleinst : moduleinst, v_globaltype : globaltype, ret_val : globaltype, var_0 : globaltype}: + `%%%`(v_moduleinst, v_globaltype, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_globaltype: `%`(v_globaltype) + -- if (ret_val = var_0) + -- wf_globaltype: `%`(ret_val) + -- fun_inst_globaltype: `%%%`(v_moduleinst, v_globaltype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_reftype(v_moduleinst : moduleinst, v_reftype : reftype) : reftype +relation fun_inst_memtype: `%%%`(moduleinst, memtype, memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_reftype{v_moduleinst : moduleinst, rt : reftype}(v_moduleinst, rt) = $subst_all_reftype(rt, (iter_val#4 : deftype <: typeuse)*{iter_val#4 <- v_moduleinst.TYPES_moduleinst}) + rule fun_inst_memtype_case_0{v_moduleinst : moduleinst, mt : memtype, var_0 : memtype}: + `%%%`(v_moduleinst, mt, var_0) + -- fun_subst_all_memtype: `%%%`(mt, (iter_val_6 : deftype <: typeuse)*{iter_val_6 <- v_moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_globaltype(v_moduleinst : moduleinst, v_globaltype : globaltype) : globaltype +relation inst_memtype_is_wf: `%%%`(v_moduleinst : moduleinst, v_memtype : memtype, ret_val : memtype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_globaltype{v_moduleinst : moduleinst, gt : globaltype}(v_moduleinst, gt) = $subst_all_globaltype(gt, (iter_val#5 : deftype <: typeuse)*{iter_val#5 <- v_moduleinst.TYPES_moduleinst}) + rule inst_memtype_is_wf_0{v_moduleinst : moduleinst, v_memtype : memtype, ret_val : memtype, var_0 : memtype}: + `%%%`(v_moduleinst, v_memtype, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_memtype: `%`(v_memtype) + -- if (ret_val = var_0) + -- wf_memtype: `%`(ret_val) + -- fun_inst_memtype: `%%%`(v_moduleinst, v_memtype, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_memtype(v_moduleinst : moduleinst, v_memtype : memtype) : memtype +relation fun_inst_tabletype: `%%%`(moduleinst, tabletype, tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_memtype{v_moduleinst : moduleinst, mt : memtype}(v_moduleinst, mt) = $subst_all_memtype(mt, (iter_val#6 : deftype <: typeuse)*{iter_val#6 <- v_moduleinst.TYPES_moduleinst}) + rule fun_inst_tabletype_case_0{v_moduleinst : moduleinst, tt : tabletype, var_0 : tabletype}: + `%%%`(v_moduleinst, tt, var_0) + -- fun_subst_all_tabletype: `%%%`(tt, (iter_val_7 : deftype <: typeuse)*{iter_val_7 <- v_moduleinst.TYPES_moduleinst}, var_0) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec -def $inst_tabletype(v_moduleinst : moduleinst, v_tabletype : tabletype) : tabletype +relation inst_tabletype_is_wf: `%%%`(v_moduleinst : moduleinst, v_tabletype : tabletype, ret_val : tabletype) ;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec - def $inst_tabletype{v_moduleinst : moduleinst, tt : tabletype}(v_moduleinst, tt) = $subst_all_tabletype(tt, (iter_val#7 : deftype <: typeuse)*{iter_val#7 <- v_moduleinst.TYPES_moduleinst}) + rule inst_tabletype_is_wf_0{v_moduleinst : moduleinst, v_tabletype : tabletype, ret_val : tabletype, var_0 : tabletype}: + `%%%`(v_moduleinst, v_tabletype, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_tabletype: `%`(v_tabletype) + -- if (ret_val = var_0) + -- wf_tabletype: `%`(ret_val) + -- fun_inst_tabletype: `%%%`(v_moduleinst, v_tabletype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_pure_before_ref_eq_true: `%`(instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_eq_null_0{ref_1 : ref, ref_2 : ref}: - `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) - -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) + `%`([$instr_ref(ref_1) $instr_ref(ref_2) REF_EQ_instr]) + -- if ((ref_1 = REF_NULL_ADDR_ref) /\ (ref_2 = REF_NULL_ADDR_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_instr: `%`(REF_EQ_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) + -- wf_ref: `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_pure: `%~>%`(instr*, instr*) @@ -12540,8 +16582,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule select_true{val_1 : val, val_2 : val, c : num_, t_lst_opt : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t_lst_opt)], [$instr_val(val_1)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12550,8 +16592,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule select_false{val_1 : val, val_2 : val, c : num_, t_lst_opt : valtype*?}: `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t_lst_opt)], [$instr_val(val_2)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12560,8 +16602,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule if_true{c : num_, bt : blocktype, instr_1_lst : instr*, instr_2_lst : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst)], [BLOCK_instr(bt, instr_1_lst)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst)) -- wf_instr: `%`(BLOCK_instr(bt, instr_1_lst)) @@ -12569,8 +16611,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule if_false{c : num_, bt : blocktype, instr_1_lst : instr*, instr_2_lst : instr*}: `%~>%`([CONST_instr(I32_numtype, c) `IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst)], [BLOCK_instr(bt, instr_2_lst)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(`IF%%ELSE%`_instr(bt, instr_1_lst, instr_2_lst)) -- wf_instr: `%`(BLOCK_instr(bt, instr_2_lst)) @@ -12585,13 +16627,14 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([`LABEL_%{%}%`_instr(v_n, instr'_lst, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [BR_instr(l)] ++ instr_lst)], $instr_val(v_val)^v_n{v_val <- val_lst} ++ instr'_lst) -- if ($proj_uN_0(l).0 = 0) -- wf_instr: `%`(`LABEL_%{%}%`_instr(v_n, instr'_lst, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [BR_instr(l)] ++ instr_lst)) + -- if (v_n = |val_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_label_succ{v_n : n, instr'_lst : instr*, val_lst : val*, l : labelidx, instr_lst : instr*}: - `%~>%`([`LABEL_%{%}%`_instr(v_n, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(l)] ++ instr_lst)], $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) + `%~>%`([`LABEL_%{%}%`_instr(v_n, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(l)] ++ instr_lst)], $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(mk_uN_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))]) -- if ($proj_uN_0(l).0 > 0) -- wf_instr: `%`(`LABEL_%{%}%`_instr(v_n, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(l)] ++ instr_lst)) - -- wf_instr: `%`(BR_instr(`%`_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) + -- wf_instr: `%`(BR_instr(mk_uN_labelidx(((($proj_uN_0(l).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_handler{v_n : n, catch_lst : catch*, val_lst : val*, l : labelidx, instr_lst : instr*}: @@ -12602,8 +16645,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_if_true{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], [BR_instr(l)]) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) @@ -12611,8 +16654,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_if_false{c : num_, l : labelidx}: `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + -- if ($proj_num__0(c) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) @@ -12628,8 +16671,8 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_table_ge{i : num_, l_lst : labelidx*, l' : labelidx}: `%~>%`([CONST_instr(I32_numtype, i) BR_TABLE_instr(l_lst, l')], [BR_instr(l')]) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l_lst|) + -- if ($proj_num__0(i) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l_lst, l')) -- wf_instr: `%`(BR_instr(l')) @@ -12637,60 +16680,62 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_null_null{v_val : val, l : labelidx}: `%~>%`([$instr_val(v_val) BR_ON_NULL_instr(l)], [BR_instr(l)]) - -- if (v_val = `REF.NULL_ADDR`_val) + -- if (v_val = REF_NULL_ADDR_val) -- wf_val: `%`(v_val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- wf_val: `%`(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_null_addr{v_val : val, l : labelidx}: `%~>%`([$instr_val(v_val) BR_ON_NULL_instr(l)], [$instr_val(v_val)]) - -- if (v_val =/= `REF.NULL_ADDR`_val) + -- if (v_val =/= REF_NULL_ADDR_val) -- wf_val: `%`(v_val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_non_null_null{v_val : val, l : labelidx}: `%~>%`([$instr_val(v_val) BR_ON_NON_NULL_instr(l)], []) - -- if (v_val = `REF.NULL_ADDR`_val) + -- if (v_val = REF_NULL_ADDR_val) -- wf_val: `%`(v_val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) - -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- wf_val: `%`(REF_NULL_ADDR_val) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_non_null_addr{v_val : val, l : labelidx}: `%~>%`([$instr_val(v_val) BR_ON_NON_NULL_instr(l)], [$instr_val(v_val) BR_instr(l)]) - -- if (v_val =/= `REF.NULL_ADDR`_val) + -- if (v_val =/= REF_NULL_ADDR_val) -- wf_val: `%`(v_val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call_indirect{x : idx, yy : typeuse}: - `%~>%`([CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) CALL_REF_instr(yy)]) + `%~>%`([CALL_INDIRECT_instr(x, yy)], [TABLE_GET_instr(x) REF_CAST_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) CALL_REF_instr(yy)]) -- wf_instr: `%`(CALL_INDIRECT_instr(x, yy)) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) + -- wf_instr: `%`(TABLE_GET_instr(x)) + -- wf_instr: `%`(REF_CAST_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_indirect{x : idx, yy : typeuse}: - `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [`TABLE.GET`_instr(x) `REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) RETURN_CALL_REF_instr(yy)]) + `%~>%`([RETURN_CALL_INDIRECT_instr(x, yy)], [TABLE_GET_instr(x) REF_CAST_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy))) RETURN_CALL_REF_instr(yy)]) -- wf_instr: `%`(RETURN_CALL_INDIRECT_instr(x, yy)) - -- wf_instr: `%`(`TABLE.GET`_instr(x)) - -- wf_instr: `%`(`REF.CAST`_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) + -- wf_instr: `%`(TABLE_GET_instr(x)) + -- wf_instr: `%`(REF_CAST_instr(REF_reftype(?(NULL_null), $heaptype_typeuse(yy)))) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule frame_vals{v_n : n, f : frame, val_lst : val*}: `%~>%`([`FRAME_%{%}%`_instr(v_n, f, $instr_val(v_val)^v_n{v_val <- val_lst})], $instr_val(v_val)^v_n{v_val <- val_lst}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(v_n, f, $instr_val(v_val)^v_n{v_val <- val_lst})) + -- if (v_n = |val_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_frame{v_n : n, f : frame, val'_lst : val*, val_lst : val*, instr_lst : instr*}: `%~>%`([`FRAME_%{%}%`_instr(v_n, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [RETURN_instr] ++ instr_lst)], $instr_val(v_val)^v_n{v_val <- val_lst}) -- wf_instr: `%`(`FRAME_%{%}%`_instr(v_n, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [RETURN_instr] ++ instr_lst)) + -- if (v_n = |val_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_label{v_n : n, instr'_lst : instr*, val_lst : val*, instr_lst : instr*}: @@ -12737,172 +16782,181 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule local_tee{v_val : val, x : idx}: - `%~>%`([$instr_val(v_val) `LOCAL.TEE`_instr(x)], [$instr_val(v_val) $instr_val(v_val) `LOCAL.SET`_instr(x)]) + `%~>%`([$instr_val(v_val) LOCAL_TEE_instr(x)], [$instr_val(v_val) $instr_val(v_val) LOCAL_SET_instr(x)]) -- wf_val: `%`(v_val) - -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) - -- wf_instr: `%`(`LOCAL.SET`_instr(x)) + -- wf_instr: `%`(LOCAL_TEE_instr(x)) + -- wf_instr: `%`(LOCAL_SET_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_i31{i : num_}: - `%~>%`([CONST_instr(I32_numtype, i) `REF.I31`_instr], [`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`([CONST_instr(I32_numtype, i) REF_I31_instr], [REF_I31_NUM_instr($wrap__(32, 31, !($proj_num__0(i))))]) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`REF.I31`_instr) - -- wf_instr: `%`(`REF.I31_NUM`_instr($wrap__(32, 31, !($proj_num__0(i))))) + -- wf_instr: `%`(REF_I31_instr) + -- wf_instr: `%`(REF_I31_NUM_instr($wrap__(32, 31, !($proj_num__0(i))))) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_is_null_true{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- if (v_ref = `REF.NULL_ADDR`_ref) + `%~>%`([$instr_ref(v_ref) REF_IS_NULL_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))]) + -- if (v_ref = REF_NULL_ADDR_ref) -- wf_ref: `%`(v_ref) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_instr: `%`(REF_IS_NULL_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) + -- wf_ref: `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_is_null_false{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- if (v_ref =/= `REF.NULL_ADDR`_ref) + `%~>%`([$instr_ref(v_ref) REF_IS_NULL_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))]) + -- if (v_ref =/= REF_NULL_ADDR_ref) -- wf_ref: `%`(v_ref) - -- wf_instr: `%`(`REF.IS_NULL`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) + -- wf_instr: `%`(REF_IS_NULL_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_as_non_null_null{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `REF.AS_NON_NULL`_instr], [TRAP_instr]) - -- if (v_ref = `REF.NULL_ADDR`_ref) + `%~>%`([$instr_ref(v_ref) REF_AS_NON_NULL_instr], [TRAP_instr]) + -- if (v_ref = REF_NULL_ADDR_ref) -- wf_ref: `%`(v_ref) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- wf_instr: `%`(REF_AS_NON_NULL_instr) -- wf_instr: `%`(TRAP_instr) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_ref: `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_as_non_null_addr{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `REF.AS_NON_NULL`_instr], [$instr_ref(v_ref)]) - -- if (v_ref =/= `REF.NULL_ADDR`_ref) + `%~>%`([$instr_ref(v_ref) REF_AS_NON_NULL_instr], [$instr_ref(v_ref)]) + -- if (v_ref =/= REF_NULL_ADDR_ref) -- wf_ref: `%`(v_ref) - -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- wf_instr: `%`(REF_AS_NON_NULL_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_eq_null{ref_1 : ref, ref_2 : ref}: - `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `REF.NULL_ADDR`_ref)) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) REF_EQ_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))]) + -- if ((ref_1 = REF_NULL_ADDR_ref) /\ (ref_2 = REF_NULL_ADDR_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) - -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- wf_instr: `%`(REF_EQ_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) + -- wf_ref: `%`(REF_NULL_ADDR_ref) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_eq_true{ref_1 : ref, ref_2 : ref}: - `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) REF_EQ_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))]) + -- if ((ref_1 =/= REF_NULL_ADDR_ref) \/ (ref_2 =/= REF_NULL_ADDR_ref)) -- if (ref_1 = ref_2) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + -- wf_instr: `%`(REF_EQ_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_eq_false{ref_1 : ref, ref_2 : ref}: - `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + `%~>%`([$instr_ref(ref_1) $instr_ref(ref_2) REF_EQ_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))]) -- if (ref_1 =/= ref_2) - -- if ((ref_1 =/= `REF.NULL_ADDR`_ref) \/ (ref_2 =/= `REF.NULL_ADDR`_ref)) + -- if ((ref_1 =/= REF_NULL_ADDR_ref) \/ (ref_2 =/= REF_NULL_ADDR_ref)) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) - -- wf_instr: `%`(`REF.EQ`_instr) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) + -- wf_instr: `%`(REF_EQ_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule i31_get_null{v_sx : sx}: - `%~>%`([`REF.NULL_ADDR`_instr `I31.GET`_instr(v_sx)], [TRAP_instr]) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - -- wf_instr: `%`(`I31.GET`_instr(v_sx)) + `%~>%`([REF_NULL_ADDR_instr I31_GET_instr(v_sx)], [TRAP_instr]) + -- wf_instr: `%`(REF_NULL_ADDR_instr) + -- wf_instr: `%`(I31_GET_instr(v_sx)) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule i31_get_num{i : u31, v_sx : sx}: - `%~>%`([`REF.I31_NUM`_instr(i) `I31.GET`_instr(v_sx)], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, $extend__(31, 32, v_sx, i)))]) - -- wf_instr: `%`(`REF.I31_NUM`_instr(i)) - -- wf_instr: `%`(`I31.GET`_instr(v_sx)) + `%~>%`([REF_I31_NUM_instr(i) I31_GET_instr(v_sx)], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, $extend__(31, 32, v_sx, i)))]) + -- wf_instr: `%`(REF_I31_NUM_instr(i)) + -- wf_instr: `%`(I31_GET_instr(v_sx)) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, $extend__(31, 32, v_sx, i)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new{v_val : val, v_n : n, x : idx}: - `%~>%`([$instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW`_instr(x)], $instr_val(v_val)^v_n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) + `%~>%`([$instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_instr(x)], $instr_val(v_val)^v_n{} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))]) -- wf_val: `%`(v_val) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n)))) - -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n)))) + -- wf_instr: `%`(ARRAY_NEW_instr(x)) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule extern_convert_any_null{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) - -- if (v_ref = `REF.NULL_ADDR`_ref) + `%~>%`([$instr_ref(v_ref) EXTERN_CONVERT_ANY_instr], [REF_NULL_ADDR_instr]) + -- if (v_ref = REF_NULL_ADDR_ref) -- wf_ref: `%`(v_ref) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) + -- wf_instr: `%`(EXTERN_CONVERT_ANY_instr) + -- wf_instr: `%`(REF_NULL_ADDR_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule extern_convert_any_addr{v_ref : ref}: - `%~>%`([$instr_ref(v_ref) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(v_ref)]) - -- if (v_ref =/= `REF.NULL_ADDR`_ref) - -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) - -- wf_instr: `%`(`REF.EXTERN`_instr(v_ref)) + `%~>%`([$instr_ref(v_ref) EXTERN_CONVERT_ANY_instr], [REF_EXTERN_instr(v_ref)]) + -- if (v_ref =/= REF_NULL_ADDR_ref) + -- wf_instr: `%`(EXTERN_CONVERT_ANY_instr) + -- wf_instr: `%`(REF_EXTERN_instr(v_ref)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule any_convert_extern_null: - `%~>%`([`REF.NULL_ADDR`_instr `ANY.CONVERT_EXTERN`_instr], [`REF.NULL_ADDR`_instr]) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) + `%~>%`([REF_NULL_ADDR_instr ANY_CONVERT_EXTERN_instr], [REF_NULL_ADDR_instr]) + -- wf_instr: `%`(REF_NULL_ADDR_instr) + -- wf_instr: `%`(ANY_CONVERT_EXTERN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule any_convert_extern_addr{v_ref : ref}: - `%~>%`([`REF.EXTERN`_instr(v_ref) `ANY.CONVERT_EXTERN`_instr], [$instr_ref(v_ref)]) - -- wf_instr: `%`(`REF.EXTERN`_instr(v_ref)) - -- wf_instr: `%`(`ANY.CONVERT_EXTERN`_instr) + `%~>%`([REF_EXTERN_instr(v_ref) ANY_CONVERT_EXTERN_instr], [$instr_ref(v_ref)]) + -- wf_instr: `%`(REF_EXTERN_instr(v_ref)) + -- wf_instr: `%`(ANY_CONVERT_EXTERN_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule unop_val{nt : numtype, c_1 : num_, unop : unop_, c : num_}: + rule unop_val{nt : numtype, c_1 : num_, unop : unop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) - -- if (|$fun_unop_(nt, unop, c_1)| > 0) - -- if (c <- $fun_unop_(nt, unop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule unop_trap{nt : numtype, c_1 : num_, unop : unop_}: + rule unop_trap{nt : numtype, c_1 : num_, unop : unop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) - -- if ($fun_unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) + -- fun_unop_: `%%%%`(nt, unop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule binop_val{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_}: + rule binop_val{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) - -- if (|$fun_binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $fun_binop_(nt, binop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule binop_trap{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_}: + rule binop_trap{nt : numtype, c_1 : num_, c_2 : num_, binop : binop_, var_0 : num_*}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) - -- if ($fun_binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) + -- fun_binop_: `%%%%%`(nt, binop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $fun_testop_(nt, testop, c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $fun_testop_(nt, testop, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -12910,35 +16964,41 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) RELOP_instr(nt, relop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $fun_relop_(nt, relop, c_1, c_2)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $fun_relop_(nt, relop, c_1, c_2)) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule cvtop_val{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_}: + rule cvtop_val{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, c : num_, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) - -- if (|$fun_cvtop__(nt_1, nt_2, cvtop, c_1)| > 0) - -- if (c <- $fun_cvtop__(nt_1, nt_2, cvtop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(CONST_instr(nt_2, c)) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule cvtop_trap{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__}: + rule cvtop_trap{nt_1 : numtype, c_1 : num_, nt_2 : numtype, cvtop : cvtop__, var_0 : num_*}: `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) - -- if ($fun_cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- (wf_num_: `%%`(nt_2, iter))*{iter <- var_0} -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) + -- fun_cvtop__: `%%%%%`(nt_1, nt_2, cvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvunop{c_1 : vec_, v_vvunop : vvunop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVUNOP_instr(V128_vectype, v_vvunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvunop_(V128_vectype, v_vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, v_vvunop, c_1)) + -- if (|$vvunop_(V128_vectype, v_vvunop, c_1)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvunop_(V128_vectype, v_vvunop, c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, v_vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) @@ -12946,8 +17006,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvbinop{c_1 : vec_, c_2 : vec_, v_vvbinop : vvbinop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VVBINOP_instr(V128_vectype, v_vvbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvbinop_(V128_vectype, v_vvbinop, c_1, c_2)| > 0) -- if (c <- $vvbinop_(V128_vectype, v_vvbinop, c_1, c_2)) + -- if (|$vvbinop_(V128_vectype, v_vvbinop, c_1, c_2)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvbinop_(V128_vectype, v_vvbinop, c_1, c_2)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, v_vvbinop)) @@ -12956,8 +17017,9 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, v_vvternop : vvternop, c : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VVTERNOP_instr(V128_vectype, v_vvternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$vvternop_(V128_vectype, v_vvternop, c_1, c_2, c_3)| > 0) -- if (c <- $vvternop_(V128_vectype, v_vvternop, c_1, c_2, c_3)) + -- if (|$vvternop_(V128_vectype, v_vvternop, c_1, c_2, c_3)| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- $vvternop_(V128_vectype, v_vvternop, c_1, c_2, c_3)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) @@ -12967,1609 +17029,1841 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vvtestop{c_1 : vec_, c : num_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- wf_uN: `%%`(32, $inez_($vsize(V128_vectype), c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vunop_val{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_}: + rule vunop_val{c_1 : vec_, sh : shape, vunop : vunop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$fun_vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $fun_vunop_(sh, vunop, c_1)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vunop_trap{c_1 : vec_, sh : shape, vunop : vunop_}: + rule vunop_trap{c_1 : vec_, sh : shape, vunop : vunop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) - -- if ($fun_vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vunop_: `%%%%`(sh, vunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbinop_val{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_}: + rule vbinop_val{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$fun_vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $fun_vbinop_(sh, vbinop, c_1, c_2)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbinop_trap{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_}: + rule vbinop_trap{c_1 : vec_, c_2 : vec_, sh : shape, vbinop : vbinop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) - -- if ($fun_vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vbinop_: `%%%%%`(sh, vbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vternop_val{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_}: + rule vternop_val{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, c : vec_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [VCONST_instr(V128_vectype, c)]) - -- if (|$fun_vternop_(sh, vternop, c_1, c_2, c_3)| > 0) - -- if (c <- $fun_vternop_(sh, vternop, c_1, c_2, c_3)) + -- if (c <- var_0) + -- if (|var_0| > 0) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vternop_trap{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_}: + rule vternop_trap{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh : shape, vternop : vternop_, var_0 : vec_*}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VTERNOP_instr(sh, vternop)], [TRAP_instr]) - -- if ($fun_vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- (wf_uN: `%%`(128, iter))*{iter <- var_0} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(TRAP_instr) + -- fun_vternop_: `%%%%%%`(sh, vternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vtestop{c_1 : vec_, v_Jnn : Jnn, v_M : M, c : num_, i_lst : lane_*}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), mk_vtestop__0_vtestop_(v_Jnn, v_M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) - -- if (i_lst = $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c_1)) + rule vtestop{c_1 : vec_, v_Jnn : Jnn, v_M : M, c : num_, i_lst : lane_*, var_0 : nat}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VTESTOP_instr(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), mk_vtestop__0_vtestop_(v_Jnn, v_M, ALL_TRUE_vtestop_Jnn_M))], [CONST_instr(I32_numtype, c)]) + -- if (i_lst = $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c_1)) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) -- if ($proj_num__0(c) =/= ?()) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), i))*{i <- i_lst} + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c_1)} + -- (wf_uN: `%%`(32, $inez_($jsizenn(v_Jnn), !($proj_lane__2(i)))))*{i <- i_lst} -- (if ($proj_lane__2(i) =/= ?()))*{i <- i_lst} - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0($inez_($jsizenn(v_Jnn), !($proj_lane__2(i)))).0*{i <- i_lst})) - -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), i))*{i <- i_lst} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), mk_vtestop__0_vtestop_(v_Jnn, v_M, ALL_TRUE_vtestop_Jnn_M))) + -- wf_instr: `%`(VTESTOP_instr(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), mk_vtestop__0_vtestop_(v_Jnn, v_M, ALL_TRUE_vtestop_Jnn_M))) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) + -- fun_prod: `%%`($proj_uN_0($inez_($jsizenn(v_Jnn), !($proj_lane__2(i)))).0*{i <- i_lst}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_}: + rule vrelop{c_1 : vec_, c_2 : vec_, sh : shape, vrelop : vrelop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VRELOP_instr(sh, vrelop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $fun_vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VRELOP_instr(sh, vrelop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vrelop_: `%%%%%`(sh, vrelop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_}: + rule vshiftop{c_1 : vec_, i : num_, sh : ishape, vshiftop : vshiftop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (c = $fun_vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshiftop_: `%%%%%`(sh, vshiftop, c_1, !($proj_num__0(i)), var_0) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vbitmask{c_1 : vec_, sh : ishape, c : num_}: + rule vbitmask{c_1 : vec_, sh : ishape, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) + -- if (!($proj_num__0(c)) = var_0) -- if ($proj_num__0(c) =/= ?()) - -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) + -- wf_uN: `%%`(32, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- fun_vbitmaskop_: `%%%`(sh, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_}: + rule vswizzlop{c_1 : vec_, c_2 : vec_, sh : bshape, swizzlop : vswizzlop_, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $fun_vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSWIZZLOP_instr(sh, swizzlop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vswizzlop_: `%%%%%`(sh, swizzlop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, i_lst : laneidx*, c : vec_}: + rule vshuffle{c_1 : vec_, c_2 : vec_, sh : bshape, i_lst : laneidx*, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSHUFFLE_instr(sh, i_lst)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vshufflop_(sh, i_lst, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VSHUFFLE_instr(sh, i_lst)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vshufflop_: `%%%%%`(sh, i_lst, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vsplat{v_Lnn : Lnn, c_1 : num_, v_M : M, c : vec_}: - `%~>%`([CONST_instr($lunpack(v_Lnn), c_1) VSPLAT_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)))], [VCONST_instr(V128_vectype, c)]) - -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, `%`_dim(v_M)), $lpacknum_(v_Lnn, c_1)^v_M{})) + `%~>%`([CONST_instr($lunpack(v_Lnn), c_1) VSPLAT_instr(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)))], [VCONST_instr(V128_vectype, c)]) + -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), $lpacknum_(v_Lnn, c_1)^v_M{})) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), $lpacknum_(v_Lnn, c_1)^v_M{})) + -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape(v_Lnn, mk_dim_dim(v_M))), $lpacknum_(v_Lnn, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(v_Lnn), c_1)) - -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)))) + -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape(v_Lnn, `%`_dim(v_M))) + -- wf_shape: `%`(`%X%`_shape(v_Lnn, mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vextract_lane_num{c_1 : vec_, nt : numtype, v_M : M, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M)), ?(), i)], [CONST_instr(nt, c_2)]) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M)), c_1)|) - -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M)), c_1)[$proj_uN_0(i).0]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M)), ?(), i)], [CONST_instr(nt, c_2)]) + -- if (mk_lane__0_lane_(nt, c_2) = $lanes_(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M)), c_1)[$proj_uN_0(i).0]) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M)), c_1)|) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M)), ?(), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M)), ?(), i)) -- wf_instr: `%`(CONST_instr(nt, c_2)) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M))), mk_lane__0_lane_(nt, c_2)) - -- wf_shape: `%`(`%X%`_shape($lanetype_numtype(nt), `%`_dim(v_M))) + -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M))), mk_lane__0_lane_(nt, c_2)) + -- wf_shape: `%`(`%X%`_shape($lanetype_numtype(nt), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vextract_lane_pack{c_1 : vec_, pt : packtype, v_M : M, v_sx : sx, i : laneidx, c_2 : num_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M)), ?(v_sx), i)], [CONST_instr(I32_numtype, c_2)]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), ?(v_sx), i)], [CONST_instr(I32_numtype, c_2)]) + -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, v_sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), c_1)[$proj_uN_0(i).0])))) -- if ($proj_num__0(c_2) =/= ?()) - -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M)), c_1)[$proj_uN_0(i).0]) =/= ?()) - -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M)), c_1)|) - -- if (!($proj_num__0(c_2)) = $extend__($psize(pt), 32, v_sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M)), c_1)[$proj_uN_0(i).0])))) + -- if ($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), c_1)[$proj_uN_0(i).0]) =/= ?()) + -- if ($proj_uN_0(i).0 < |$lanes_(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), c_1)|) + -- wf_uN: `%%`(32, $extend__($psize(pt), 32, v_sx, !($proj_lane__1($lanes_(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), c_1)[$proj_uN_0(i).0])))) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), c_1)} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) - -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M)), ?(v_sx), i)) + -- wf_instr: `%`(VEXTRACT_LANE_instr(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M)), ?(v_sx), i)) -- wf_instr: `%`(CONST_instr(I32_numtype, c_2)) - -- wf_shape: `%`(`%X%`_shape($lanetype_packtype(pt), `%`_dim(v_M))) + -- wf_shape: `%`(`%X%`_shape($lanetype_packtype(pt), mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vreplace_lane{c_1 : vec_, v_Lnn : Lnn, c_2 : num_, v_M : M, i : laneidx, c : vec_}: - `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(v_Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)), i)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, `%`_dim(v_M)), $lanes_(`%X%`_shape(v_Lnn, `%`_dim(v_M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(v_Lnn, c_2)])) + `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr($lunpack(v_Lnn), c_2) VREPLACE_LANE_instr(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), i)], [VCONST_instr(V128_vectype, c)]) + -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), $lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(v_Lnn, c_2)])) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), $lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), c_1)[[$proj_uN_0(i).0] = $lpacknum_(v_Lnn, c_2)])) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(v_Lnn, mk_dim_dim(v_M))), iter))*{iter <- $lanes_(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), c_1)} + -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape(v_Lnn, mk_dim_dim(v_M))), $lpacknum_(v_Lnn, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(CONST_instr($lunpack(v_Lnn), c_2)) - -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)), i)) + -- wf_instr: `%`(VREPLACE_LANE_instr(`%X%`_shape(v_Lnn, mk_dim_dim(v_M)), i)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape(v_Lnn, `%`_dim(v_M))) + -- wf_shape: `%`(`%X%`_shape(v_Lnn, mk_dim_dim(v_M))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_}: + rule vextunop{c_1 : vec_, sh_2 : ishape, sh_1 : ishape, vextunop : vextunop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTUNOP_instr(sh_2, sh_1, vextunop)], [VCONST_instr(V128_vectype, c)]) - -- if ($fun_vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextunop__: `%%%%%`(sh_1, sh_2, vextunop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_}: + rule vextbinop{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, vextbinop : vextbinop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VEXTBINOP_instr(sh_2, sh_1, vextbinop)], [VCONST_instr(V128_vectype, c)]) - -- if ($fun_vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VEXTBINOP_instr(sh_2, sh_1, vextbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextbinop__: `%%%%%%`(sh_1, sh_2, vextbinop, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_}: + rule vextternop{c_1 : vec_, c_2 : vec_, c_3 : vec_, sh_2 : ishape, sh_1 : ishape, vextternop : vextternop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VCONST_instr(V128_vectype, c_3) VEXTTERNOP_instr(sh_2, sh_1, vextternop)], [VCONST_instr(V128_vectype, c)]) - -- if ($fun_vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = c) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VEXTTERNOP_instr(sh_2, sh_1, vextternop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vextternop__: `%%%%%%%`(sh_1, sh_2, vextternop, c_1, c_2, c_3, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, v_sx : sx, c : vec_}: + rule vnarrow{c_1 : vec_, c_2 : vec_, sh_2 : ishape, sh_1 : ishape, v_sx : sx, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VNARROW_instr(sh_2, sh_1, v_sx)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, v_sx, c_1, c_2)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VNARROW_instr(sh_2, sh_1, v_sx)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vnarrowop__: `%%%%%%`($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, v_sx, c_1, c_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_}: + rule vcvtop{c_1 : vec_, sh_2 : shape, sh_1 : shape, vcvtop : vcvtop__, c : vec_, var_0 : vec_}: `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) - -- if (c = $fun_vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- wf_uN: `%%`(128, var_0) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- fun_vcvtop__: `%%%%%`(sh_1, sh_2, vcvtop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -def $blocktype_(v_state : state, v_blocktype : blocktype) : instrtype +relation fun_blocktype_: `%%%`(state, blocktype, instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, x : uN, t_1_lst : valtype*, t_2_lst : valtype*}(z, _IDX_blocktype(x)) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst)) - -- Expand: `%~~%`($fun_type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + rule fun_blocktype__case_0{z : state, x : uN, t_1_lst : valtype*, t_2_lst : valtype*}: + `%%%`(z, _IDX_blocktype(x), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Expand: `%~~%`($fun_type(z, x), `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule fun_blocktype__case_1{z : state, t_opt : valtype?}: + `%%%`(z, _RESULT_blocktype(t_opt), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(lift(t_opt)))) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation blocktype__is_wf: `%%%`(v_state : state, v_blocktype : blocktype, ret_val : instrtype) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - def $blocktype_{z : state, t_opt : valtype?}(z, _RESULT_blocktype(t_opt)) = `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t_opt))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t_opt)))) + rule blocktype__is_wf_0{v_state : state, v_blocktype : blocktype, ret_val : instrtype, var_0 : instrtype}: + `%%%`(v_state, v_blocktype, ret_val) + -- wf_state: `%`(v_state) + -- wf_blocktype: `%`(v_blocktype) + -- if (ret_val = var_0) + -- wf_instrtype: `%`(ret_val) + -- fun_blocktype_: `%%%`(v_state, v_blocktype, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_br_on_cast_fail: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule br_on_cast_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule br_on_cast_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_br_on_cast_fail_fail: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule br_on_cast_fail_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule br_on_cast_fail_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_throw_ref_handler_next: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_all_ref_0{z : state, v_n : n, l : labelidx, catch'_lst : catch*, a : addr}: - `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_all_0{z : state, v_n : n, l : labelidx, catch'_lst : catch*, a : addr}: - `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_ref_0{z : state, v_n : n, x : idx, l : labelidx, catch'_lst : catch*, a : addr, val_lst : val*}: - `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$fun_exninst(z)|) -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) - -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (val_lst = $fun_exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(v_val))*{v_val <- val_lst} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + -- (wf_exninst: `%`(iter))*{iter <- $fun_exninst(z)} + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_0{z : state, v_n : n, x : idx, l : labelidx, catch'_lst : catch*, a : addr, val_lst : val*}: - `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$fun_exninst(z)|) -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) - -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (val_lst = $fun_exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(v_val))*{v_val <- val_lst} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + -- (wf_exninst: `%`(iter))*{iter <- $fun_exninst(z)} + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_table_fill_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_fill_oob_0{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_table_copy_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_oob_0{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($fun_table(z, x_1)) + -- wf_tableinst: `%`($fun_table(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_table_copy_le: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_zero_0{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- ~ Step_read_before_table_copy_zero: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- ~ Step_read_before_table_copy_zero: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_oob_1{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($fun_table(z, x_1)) + -- wf_tableinst: `%`($fun_table(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_table_copy_gt: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_le_0{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- ~ Step_read_before_table_copy_le: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- ~ Step_read_before_table_copy_le: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) - -- wf_instr: `%`(`TABLE.GET`_instr(y)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) + -- wf_instr: `%`(TABLE_GET_instr(y)) + -- wf_instr: `%`(TABLE_SET_instr(x)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(TABLE_COPY_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_zero_1{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- ~ Step_read_before_table_copy_zero: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- ~ Step_read_before_table_copy_zero: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_oob_2{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($fun_table(z, x_1)) + -- wf_tableinst: `%`($fun_table(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_table_init_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_init_oob_0{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)])) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_memory_fill_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_fill_oob_0{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)])) - -- if ($proj_num__0(i) =/= ?()) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_memory_copy_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_oob_0{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($fun_mem(z, x_1)) + -- wf_meminst: `%`($fun_mem(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_memory_copy_le: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_zero_0{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- ~ Step_read_before_memory_copy_zero: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) + -- ~ Step_read_before_memory_copy_zero: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_oob_1{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($fun_mem(z, x_1)) + -- wf_meminst: `%`($fun_mem(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_memory_init_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_init_oob_0{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)])) + `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)])) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_ref_test_false: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule ref_test_true_0{s : store, f : frame, v_ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + rule ref_test_true_0{s : store, f : frame, v_ref : ref, rt : reftype, var_0 : reftype}: + `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)])) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_ref_cast_fail: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule ref_cast_succeed_0{s : store, f : frame, v_ref : ref, rt : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) + rule ref_cast_succeed_0{s : store, f : frame, v_ref : ref, rt : reftype, var_0 : reftype}: + `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)])) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_fill_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_fill_oob_0{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation Step_read_before_array_fill_succ: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule array_fill_zero_0{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- ~ Step_read_before_array_fill_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- if (v_n = 0) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule array_fill_oob_1{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$fun_arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_copy_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob2_0{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob1_0{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_copy_le: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_zero_0{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- ~ Step_read_before_array_copy_zero: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- ~ Step_read_before_array_copy_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob2_1{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob1_1{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_copy_gt: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_le_0{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx, sx_opt : sx?, mut_opt : mut?, zt_2 : storagetype}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- ~ Step_read_before_array_copy_le: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- ~ Step_read_before_array_copy_le: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !($fun_sx(zt_2)))) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) -- if ($fun_sx(zt_2) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !($fun_sx(zt_2)))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_2)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx_opt, x_2)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) + -- wf_instr: `%`(ARRAY_GET_instr(sx_opt, x_2)) + -- wf_instr: `%`(ARRAY_SET_instr(x_1)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_COPY_instr(x_1, x_2)) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_zero_1{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- ~ Step_read_before_array_copy_zero: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- ~ Step_read_before_array_copy_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob2_2{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob1_2{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- wf_instr: `%`(TRAP_instr) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation Step_read_before_array_init_elem_zero: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule array_init_elem_oob2_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- wf_instr: `%`(TRAP_instr) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule array_init_elem_oob1_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$fun_arrayinst(z)|) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) -;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec -relation Step_read_before_array_init_elem_zero: `%`(config) +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation Step_read_before_array_init_elem_succ: `%`(config) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule array_init_elem_zero_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- ~ Step_read_before_array_init_elem_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- if (v_n = 0) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule array_init_elem_oob2_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- if ($proj_num__0(j) =/= ?()) + rule array_init_elem_oob2_1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- if (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule array_init_elem_oob1_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + rule array_init_elem_oob1_1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_init_data_zero: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob2_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx, mut_opt : mut?, zt : storagetype}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob1_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read_before_array_init_data_num: `%`(config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_zero_0{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- ~ Step_read_before_array_init_data_zero: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- ~ Step_read_before_array_init_data_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob2_1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx, mut_opt : mut?, zt : storagetype}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob1_1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec relation Step_read: `%~>%`(config, instr*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule block{z : state, v_m : m, val_lst : val*, bt : blocktype, instr_lst : instr*, v_n : n, t_1_lst : valtype*, t_2_lst : valtype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [BLOCK_instr(bt, instr_lst)]), [`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [BLOCK_instr(bt, instr_lst)])) + rule block{z : state, v_m : m, val_lst : val*, bt : blocktype, instr_lst : instr*, v_n : n, t_1_lst : valtype*, t_2_lst : valtype*, var_0 : instrtype}: + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [BLOCK_instr(bt, instr_lst)]), [`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)]) + -- if (var_0 = mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [BLOCK_instr(bt, instr_lst)])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- if (v_m = |val_lst|) + -- if (v_m = |t_1_lst|) + -- if (v_n = |t_2_lst|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule loop{z : state, v_m : m, val_lst : val*, bt : blocktype, instr_lst : instr*, t_1_lst : valtype*, v_n : n, t_2_lst : valtype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [LOOP_instr(bt, instr_lst)]), [`LABEL_%{%}%`_instr(v_m, [LOOP_instr(bt, instr_lst)], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [LOOP_instr(bt, instr_lst)])) + rule loop{z : state, v_m : m, val_lst : val*, bt : blocktype, instr_lst : instr*, t_1_lst : valtype*, v_n : n, t_2_lst : valtype*, var_0 : instrtype}: + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [LOOP_instr(bt, instr_lst)]), [`LABEL_%{%}%`_instr(v_m, [LOOP_instr(bt, instr_lst)], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)]) + -- if (var_0 = mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [LOOP_instr(bt, instr_lst)])) -- wf_instr: `%`(`LABEL_%{%}%`_instr(v_m, [LOOP_instr(bt, instr_lst)], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- if (v_m = |val_lst|) + -- if (v_m = |t_1_lst|) + -- if (v_n = |t_2_lst|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule br_on_cast_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref) BR_instr(l)]) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + rule br_on_cast_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref) BR_instr(l)]) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_cast_fail{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref)]) - -- ~ Step_read_before_br_on_cast_fail: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref)]) + -- ~ Step_read_before_br_on_cast_fail: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule br_on_cast_fail_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref)]) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt_2)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + rule br_on_cast_fail_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, var_0 : reftype}: + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref)]) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule br_on_cast_fail_fail{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref) BR_instr(l)]) - -- ~ Step_read_before_br_on_cast_fail_fail: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref) BR_instr(l)]) + -- ~ Step_read_before_br_on_cast_fail_fail: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$fun_funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$fun_moduleinst(z).FUNCS_moduleinst|) + `%~>%`(mk_config_config(z, [CALL_instr(x)]), [REF_FUNC_ADDR_instr(a) CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))]) -- if ($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) - -- wf_config: `%`(`%;%`_config(z, [CALL_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) + -- if ($proj_uN_0(x).0 < |$fun_moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($fun_moduleinst(z)) + -- wf_config: `%`(mk_config_config(z, [CALL_instr(x)])) + -- wf_instr: `%`(REF_FUNC_ADDR_instr(a)) -- wf_instr: `%`(CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$fun_funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call_ref_null{z : state, yy : typeuse}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CALL_REF_instr(yy)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CALL_REF_instr(yy)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CALL_REF_instr(yy)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CALL_REF_instr(yy)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule call_ref_func{z : state, v_n : n, val_lst : val*, a : addr, yy : typeuse, v_m : m, f : frame, instr_lst : instr*, fi : funcinst, t_1_lst : valtype*, t_2_lst : valtype*, x : idx, t_lst : valtype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(v_m, f, [`LABEL_%{%}%`_instr(v_m, [], instr_lst)])]) - -- if (a < |$fun_funcinst(z)|) + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(a) CALL_REF_instr(yy)]), [`FRAME_%{%}%`_instr(v_m, f, [`LABEL_%{%}%`_instr(v_m, [], instr_lst)])]) -- if ($fun_funcinst(z)[a] = fi) - -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- if (a < |$fun_funcinst(z)|) + -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- t_lst}, instr_lst)) - -- (if ($default_(t) =/= ?()))*{t <- t_lst} -- if (f = {LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !($default_(t))*{t <- t_lst}, MODULE fi.MODULE_funcinst}) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) + -- (if ($default_(t) =/= ?()))*{t <- t_lst} + -- (wf_funcinst: `%`(iter))*{iter <- $fun_funcinst(z)} + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(a) CALL_REF_instr(yy)])) -- wf_instr: `%`(`FRAME_%{%}%`_instr(v_m, f, [`LABEL_%{%}%`_instr(v_m, [], instr_lst)])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- wf_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- t_lst}, instr_lst)) -- wf_frame: `%`({LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !($default_(t))*{t <- t_lst}, MODULE fi.MODULE_funcinst}) + -- if (v_n = |val_lst|) + -- if (v_n = |t_1_lst|) + -- if (v_m = |t_2_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: - `%~>%`(`%;%`_config(z, [RETURN_CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))]) - -- if (a < |$fun_funcinst(z)|) - -- if ($proj_uN_0(x).0 < |$fun_moduleinst(z).FUNCS_moduleinst|) + `%~>%`(mk_config_config(z, [RETURN_CALL_instr(x)]), [REF_FUNC_ADDR_instr(a) RETURN_CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))]) -- if ($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) - -- wf_config: `%`(`%;%`_config(z, [RETURN_CALL_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) + -- if ($proj_uN_0(x).0 < |$fun_moduleinst(z).FUNCS_moduleinst|) + -- wf_moduleinst: `%`($fun_moduleinst(z)) + -- wf_config: `%`(mk_config_config(z, [RETURN_CALL_instr(x)])) + -- wf_instr: `%`(REF_FUNC_ADDR_instr(a)) -- wf_instr: `%`(RETURN_CALL_REF_instr($typeuse_deftype($fun_funcinst(z)[a].TYPE_funcinst))) + -- if (a < |$fun_funcinst(z)|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_ref_label{z : state, k : n, instr'_lst : instr*, val_lst : val*, yy : typeuse, instr_lst : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(k, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) + `%~>%`(mk_config_config(z, [`LABEL_%{%}%`_instr(k, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(mk_config_config(z, [`LABEL_%{%}%`_instr(k, instr'_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_ref_handler{z : state, k : n, catch_lst : catch*, val_lst : val*, yy : typeuse, instr_lst : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(k, catch_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(k, catch_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)]) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(k, catch_lst, $instr_val(v_val)*{v_val <- val_lst} ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) -- wf_instr: `%`(RETURN_CALL_REF_instr(yy)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_ref_frame_null{z : state, k : n, f : frame, val_lst : val*, yy : typeuse, instr_lst : instr*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.NULL_ADDR`_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) + `%~>%`(mk_config_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(v_val)*{v_val <- val_lst} ++ [REF_NULL_ADDR_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(v_val)*{v_val <- val_lst} ++ [REF_NULL_ADDR_instr] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call_ref_frame_addr{z : state, k : n, f : frame, val'_lst : val*, v_n : n, val_lst : val*, a : addr, yy : typeuse, instr_lst : instr*, t_1_lst : valtype*, v_m : m, t_2_lst : valtype*}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)]) + `%~>%`(mk_config_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)]), $instr_val(v_val)^v_n{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(a) CALL_REF_instr(yy)]) + -- Expand: `%~~%`($fun_funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) -- if (a < |$fun_funcinst(z)|) - -- Expand: `%~~%`($fun_funcinst(z)[a].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr(a)) + -- (wf_funcinst: `%`(iter))*{iter <- $fun_funcinst(z)} + -- wf_config: `%`(mk_config_config(z, [`FRAME_%{%}%`_instr(k, f, $instr_val(val')*{val' <- val'_lst} ++ $instr_val(v_val)^v_n{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(a)] ++ [RETURN_CALL_REF_instr(yy)] ++ instr_lst)])) + -- wf_instr: `%`(REF_FUNC_ADDR_instr(a)) -- wf_instr: `%`(CALL_REF_instr(yy)) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- if (v_n = |val_lst|) + -- if (v_n = |t_1_lst|) + -- if (v_m = |t_2_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_null{z : state}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr THROW_REF_instr]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr THROW_REF_instr])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr THROW_REF_instr]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr THROW_REF_instr])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_instrs{z : state, val_lst : val*, a : addr, instr_lst : instr*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr_lst), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) + `%~>%`(mk_config_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ [REF_EXN_ADDR_instr(a)] ++ [THROW_REF_instr] ++ instr_lst), [REF_EXN_ADDR_instr(a) THROW_REF_instr]) -- if ((val_lst =/= []) \/ (instr_lst =/= [])) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr_lst)) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ [REF_EXN_ADDR_instr(a)] ++ [THROW_REF_instr] ++ instr_lst)) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(THROW_REF_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_label{z : state, v_n : n, instr'_lst : instr*, a : addr}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(v_n, instr'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(v_n, instr'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + `%~>%`(mk_config_config(z, [`LABEL_%{%}%`_instr(v_n, instr'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [REF_EXN_ADDR_instr(a) THROW_REF_instr]) + -- wf_config: `%`(mk_config_config(z, [`LABEL_%{%}%`_instr(v_n, instr'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(THROW_REF_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_frame{z : state, v_n : n, f : frame, a : addr}: - `%~>%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(v_n, f, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`FRAME_%{%}%`_instr(v_n, f, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + `%~>%`(mk_config_config(z, [`FRAME_%{%}%`_instr(v_n, f, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [REF_EXN_ADDR_instr(a) THROW_REF_instr]) + -- wf_config: `%`(mk_config_config(z, [`FRAME_%{%}%`_instr(v_n, f, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(THROW_REF_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_empty{z : state, v_n : n, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [], [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [], [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [], [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [REF_EXN_ADDR_instr(a) THROW_REF_instr]) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [], [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(THROW_REF_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch{z : state, v_n : n, x : idx, l : labelidx, catch'_lst : catch*, a : addr, val_lst : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(l)]) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), $instr_val(v_val)*{v_val <- val_lst} ++ [BR_instr(l)]) + -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$fun_exninst(z)|) -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) - -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (val_lst = $fun_exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(v_val))*{v_val <- val_lst} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + -- (wf_exninst: `%`(iter))*{iter <- $fun_exninst(z)} + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_ref{z : state, v_n : n, x : idx, l : labelidx, catch'_lst : catch*, a : addr, val_lst : val*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), $instr_val(v_val)*{v_val <- val_lst} ++ [REF_EXN_ADDR_instr(a) BR_instr(l)]) + -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (a < |$fun_exninst(z)|) -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) - -- if ($fun_exninst(z)[a].TAG_exninst = $fun_tagaddr(z)[$proj_uN_0(x).0]) -- if (val_lst = $fun_exninst(z)[a].FIELDS_exninst) -- (wf_val: `%`(v_val))*{v_val <- val_lst} - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + -- (wf_exninst: `%`(iter))*{iter <- $fun_exninst(z)} + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_REF_catch(x, l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_all{z : state, v_n : n, l : labelidx, catch'_lst : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [BR_instr(l)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [BR_instr(l)]) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_catch_all_ref{z : state, v_n : n, l : labelidx, catch'_lst : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`REF.EXN_ADDR`_instr(a) BR_instr(l)]) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`REF.EXN_ADDR`_instr(a)) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [REF_EXN_ADDR_instr(a) BR_instr(l)]) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [CATCH_ALL_REF_catch(l)] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(REF_EXN_ADDR_instr(a)) -- wf_instr: `%`(BR_instr(l)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule throw_ref_handler_next{z : state, v_n : n, v_catch : catch, catch'_lst : catch*, a : addr}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]), [`HANDLER_%{%}%`_instr(v_n, catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])]) - -- ~ Step_read_before_throw_ref_handler_next: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])])) - -- wf_instr: `%`(`HANDLER_%{%}%`_instr(v_n, catch'_lst, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]), [`HANDLER_%{%}%`_instr(v_n, catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])]) + -- ~ Step_read_before_throw_ref_handler_next: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, [v_catch] ++ catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])])) + -- wf_instr: `%`(`HANDLER_%{%}%`_instr(v_n, catch'_lst, [REF_EXN_ADDR_instr(a) THROW_REF_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule try_table{z : state, v_m : m, val_lst : val*, bt : blocktype, catch_lst : catch*, instr_lst : instr*, v_n : n, t_1_lst : valtype*, t_2_lst : valtype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [TRY_TABLE_instr(bt, `%`_list(catch_lst), instr_lst)]), [`HANDLER_%{%}%`_instr(v_n, catch_lst, [`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)])]) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [TRY_TABLE_instr(bt, `%`_list(catch_lst), instr_lst)])) + rule try_table{z : state, v_m : m, val_lst : val*, bt : blocktype, catch_lst : catch*, instr_lst : instr*, v_n : n, t_1_lst : valtype*, t_2_lst : valtype*, var_0 : instrtype}: + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [TRY_TABLE_instr(bt, mk_list_list(catch_lst), instr_lst)]), [`HANDLER_%{%}%`_instr(v_n, catch_lst, [`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)])]) + -- if (var_0 = mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(var_0) + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [TRY_TABLE_instr(bt, mk_list_list(catch_lst), instr_lst)])) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(v_n, catch_lst, [`LABEL_%{%}%`_instr(v_n, [], $instr_val(v_val)^v_m{v_val <- val_lst} ++ instr_lst)])) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- if (v_m = |val_lst|) + -- if (v_m = |t_1_lst|) + -- if (v_n = |t_2_lst|) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule local_get{z : state, x : idx, v_val : val}: - `%~>%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)]), [$instr_val(v_val)]) + `%~>%`(mk_config_config(z, [LOCAL_GET_instr(x)]), [$instr_val(v_val)]) -- if ($fun_local(z, x) = ?(v_val)) -- wf_val: `%`(v_val) - -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) + -- (wf_val: `%`(iter))?{iter <- $fun_local(z, x)} + -- wf_config: `%`(mk_config_config(z, [LOCAL_GET_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule global_get{z : state, x : idx, v_val : val}: - `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(v_val)]) + `%~>%`(mk_config_config(z, [GLOBAL_GET_instr(x)]), [$instr_val(v_val)]) -- if ($fun_global(z, x).VALUE_globalinst = v_val) -- wf_val: `%`(v_val) - -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) + -- wf_globalinst: `%`($fun_global(z, x)) + -- wf_config: `%`(mk_config_config(z, [GLOBAL_GET_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_get_oob{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) TABLE_GET_instr(x)]), [TRAP_instr]) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) TABLE_GET_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_get_val{z : state, at : addrtype, i : num_, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [$instr_ref($fun_table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) TABLE_GET_instr(x)]), [$instr_ref($fun_table(z, x).REFS_tableinst[$proj_uN_0(!($proj_num__0(i))).0])]) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$fun_table(z, x).REFS_tableinst|) -- if ($proj_num__0(i) =/= ?()) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) TABLE_GET_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_size{z : state, x : idx, at : addrtype, v_n : n, lim : limits, rt : reftype}: - `%~>%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n)))]) + `%~>%`(mk_config_config(z, [TABLE_SIZE_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n)))]) -- if (|$fun_table(z, x).REFS_tableinst| = v_n) - -- if ($fun_table(z, x).TYPE_tableinst = `%%%`_tabletype(at, lim, rt)) - -- wf_config: `%`(`%;%`_config(z, [`TABLE.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n)))) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- if ($fun_table(z, x).TYPE_tableinst = mk_tabletype_tabletype(at, lim, rt)) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [TABLE_SIZE_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n)))) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_fill_oob{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_fill_zero{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)]), []) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_table(z, x).REFS_tableinst|) + -- if ($proj_num__0(i) =/= ?()) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_fill_succ{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) TABLE_SET_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) TABLE_FILL_instr(x)]) -- if (v_n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_FILL_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.FILL`_instr(x)) + -- wf_instr: `%`(TABLE_SET_instr(x)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(TABLE_FILL_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_oob{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_table(z, x_1).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_table(z, x_2).REFS_tableinst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x_1, x_2)])) + -- wf_tableinst: `%`($fun_table(z, x_1)) + -- wf_tableinst: `%`($fun_table(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_zero{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)]), []) - -- ~ Step_read_before_table_copy_zero: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)]), []) + -- ~ Step_read_before_table_copy_zero: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_le{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) TABLE_GET_instr(y) TABLE_SET_instr(x) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) TABLE_COPY_instr(x, y)]) + -- ~ Step_read_before_table_copy_le: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- ~ Step_read_before_table_copy_le: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) - -- wf_instr: `%`(`TABLE.GET`_instr(y)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) + -- wf_instr: `%`(TABLE_GET_instr(y)) + -- wf_instr: `%`(TABLE_SET_instr(x)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(TABLE_COPY_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_copy_gt{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.GET`_instr(y) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.COPY`_instr(x, y)]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) TABLE_GET_instr(y) TABLE_SET_instr(x) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) TABLE_COPY_instr(x, y)]) + -- ~ Step_read_before_table_copy_gt: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) TABLE_COPY_instr(x, y)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_2) =/= ?()) - -- ~ Step_read_before_table_copy_gt: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `TABLE.COPY`_instr(x, y)])) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.GET`_instr(y)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) + -- wf_instr: `%`(TABLE_GET_instr(y)) + -- wf_instr: `%`(TABLE_SET_instr(x)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.COPY`_instr(x, y)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(TABLE_COPY_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_init_oob{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_table(z, x).REFS_tableinst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)])) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_init_zero{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)]), []) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_elem(z, y).REFS_eleminst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_elem(z, y).REFS_eleminst|)) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule table_init_succ{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) `TABLE.SET`_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `TABLE.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) $instr_ref($fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) TABLE_SET_instr(x) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) TABLE_INIT_instr(x, y)]) -- if (v_n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_table(z, x).REFS_tableinst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_elem(z, y).REFS_eleminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(x, y)])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) - -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`TABLE.INIT`_instr(x, y)) + -- wf_instr: `%`(TABLE_SET_instr(x)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(TABLE_INIT_instr(x, y)) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule load_num_oob{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule load_num_val{z : state, at : addrtype, i : num_, nt : numtype, x : idx, ao : memarg, c : num_}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- if ($nbytes_(nt, c) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(CONST_instr(nt, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule load_pack_oob{z : state, at : addrtype, i : num_, v_Inn : Inn, v_n : n, v_sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_n), v_sx))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_n), v_sx))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_n), v_sx))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_n), v_sx))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule load_pack_val{z : state, at : addrtype, i : num_, v_Inn : Inn, v_n : n, v_sx : sx, x : idx, ao : memarg, c : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_n), v_sx))), x, ao)]), [CONST_instr($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, $extend__(v_n, $size($numtype_addrtype(v_Inn)), v_sx, c)))]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_n), v_sx))), x, ao)]), [CONST_instr($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, $extend__(v_n, $size($numtype_addrtype(v_Inn)), v_sx, c)))]) -- if ($ibytes_(v_n, c) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, `%_%`_loadop_Inn(`%`_sz(v_n), v_sx))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_n, c)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr($numtype_addrtype(v_Inn), ?(mk_loadop__0_loadop_(v_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(v_n), v_sx))), x, ao)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(v_Inn), mk_num__0_num_(v_Inn, $extend__(v_n, $size($numtype_addrtype(v_Inn)), v_sx, c)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_oob{z : state, at : addrtype, i : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_val{z : state, at : addrtype, i : num_, x : idx, ao : memarg, c : vec_}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($vbytes_(V128_vectype, c) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_pack_oob{z : state, at : addrtype, i : num_, v_M : M, v_K : K, v_sx : sx, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(v_M), v_K, v_sx)), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(v_M), v_K, v_sx)), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((v_M * v_K) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(v_M), v_K, v_sx)), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(v_M), v_K, v_sx)), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_pack_val{z : state, at : addrtype, i : num_, v_M : M, v_K : K, v_sx : sx, x : idx, ao : memarg, c : vec_, j_lst : iN*, v_Jnn : Jnn}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(v_M), v_K, v_sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- (if ($proj_num__0(i) =/= ?()))^(k%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(v_M), v_K, v_sx)), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- (if ($ibytes_(v_M, j) = $fun_mem(z, x).BYTES_meminst[(($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((((k * v_M) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((v_M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_splat_val{z : state, at : addrtype, i : num_, v_N : N, x : idx, ao : memarg, c : vec_, j : iN, v_Jnn : Jnn, v_M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(v_N, j) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (v_N = $jsize(v_Jnn)) -- if ((v_M : nat <:> rat) = ((128 : nat <:> rat) / (v_N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), mk_lane__2_lane_(v_Jnn, `%`_uN($proj_uN_0(j).0))^v_M{})) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(v_N))), x, ao)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(j).0))^v_M{})) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_N, j)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(j).0))^v_M{})) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(v_N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(v_Jnn, `%`_uN($proj_uN_0(j).0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) + -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(j).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_zero_oob{z : state, at : addrtype, i : num_, v_N : N, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, ao)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, ao)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, ao)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, ao)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_zero_val{z : state, at : addrtype, i : num_, v_N : N, x : idx, ao : memarg, c : vec_, j : iN}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(v_N, j) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (c = $extend__(v_N, 128, U_sx, j)) -- wf_uN: `%%`(v_N, j) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(v_N))), x, ao)])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_N, j)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_uN: `%%`(128, $extend__(v_N, 128, U_sx, j)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(v_N))), x, ao)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_lane_oob{z : state, at : addrtype, i : num_, c_1 : vec_, v_N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)]), [TRAP_instr]) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule vload_lane_val{z : state, at : addrtype, i : num_, c_1 : vec_, v_N : N, x : idx, ao : memarg, j : laneidx, c : vec_, k : iN, v_Jnn : Jnn, v_M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)]), [VCONST_instr(V128_vectype, c)]) -- if ($ibytes_(v_N, k) = $fun_mem(z, x).BYTES_meminst[($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) : (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- if ($proj_num__0(i) =/= ?()) -- if (v_N = $jsize(v_Jnn)) -- if ((v_M : nat <:> rat) = (($vsize(V128_vectype) : nat <:> rat) / (v_N : nat <:> rat))) - -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(v_Jnn, `%`_uN($proj_uN_0(k).0))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)])) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(k).0))])) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_N, k)} + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_uN: `%%`(128, $inv_lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c_1)[[$proj_uN_0(j).0] = mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(k).0))])) + -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), iter))*{iter <- $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c_1)} + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c_1) VLOAD_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)])) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) - -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))), mk_lane__2_lane_(v_Jnn, `%`_uN($proj_uN_0(k).0))) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))) + -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M))), mk_lane__2_lane_(v_Jnn, mk_uN_uN($proj_uN_0(k).0))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_size{z : state, x : idx, at : addrtype, v_n : n, lim : limits}: - `%~>%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n)))]) + `%~>%`(mk_config_config(z, [MEMORY_SIZE_instr(x)]), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n)))]) -- if ((v_n * (64 * $Ki)) = |$fun_mem(z, x).BYTES_meminst|) -- if ($fun_mem(z, x).TYPE_meminst = `%%PAGE`_memtype(at, lim)) - -- wf_config: `%`(`%;%`_config(z, [`MEMORY.SIZE`_instr(x)])) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n)))) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [MEMORY_SIZE_instr(x)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n)))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_fill_oob{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_fill_zero{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)]), []) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_mem(z, x).BYTES_meminst|) + -- if ($proj_num__0(i) =/= ?()) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_fill_succ{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)]), [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) MEMORY_FILL_instr(x)]) -- if (v_n =/= 0) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.FILL`_instr(x)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_val(v_val) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_FILL_instr(x)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, $memarg0)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(MEMORY_FILL_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_oob{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_mem(z, x_1).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_meminst: `%`($fun_mem(z, x_1)) + -- wf_meminst: `%`($fun_mem(z, x_2)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_zero{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)]), []) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_mem(z, x_2).BYTES_meminst|)) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_mem(z, x_2).BYTES_meminst|)) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_le{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) - -- if ($proj_num__0(i_1) =/= ?()) - -- if ($proj_num__0(i_2) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) MEMORY_COPY_instr(x_1, x_2)]) -- if (v_n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_mem(z, x_2).BYTES_meminst|)) + -- if ($proj_num__0(i_1) =/= ?()) + -- if ($proj_num__0(i_2) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) - -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) + -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x_2, $memarg0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x_1, $memarg0)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(MEMORY_COPY_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_copy_gt{z : state, at_1 : addrtype, i_1 : num_, at_2 : addrtype, i_2 : num_, at' : addrtype, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.COPY`_instr(x_1, x_2)]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)]), [CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x_2, $memarg0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x_1, $memarg0) CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) MEMORY_COPY_instr(x_1, x_2)]) + -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(i_1))).0 > $proj_uN_0(!($proj_num__0(i_2))).0) -- if (v_n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_mem(z, x_1).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_mem(z, x_2).BYTES_meminst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN(v_n))) `MEMORY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, $memarg0)) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, $memarg0)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at_1), i_1) CONST_instr($numtype_addrtype(at_2), i_2) CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN(v_n))) MEMORY_COPY_instr(x_1, x_2)])) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), mk_num__0_num_(at_1, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), mk_num__0_num_(at_2, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x_2, $memarg0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x_1, $memarg0)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_1), i_1)) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at'), mk_num__0_num_(at', mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(MEMORY_COPY_instr(x_1, x_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_init_oob{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)]), [TRAP_instr]) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_mem(z, x).BYTES_meminst|) \/ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_init_zero{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)]), []) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)]), []) + -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_data(z, y).BYTES_datainst|)) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_data(z, y).BYTES_datainst|)) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule memory_init_succ{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `MEMORY.INIT`_instr(x, y)]) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_data(z, y).BYTES_datainst|) - -- if ($proj_num__0(j) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)]), [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN($proj_byte_0($fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0))) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, $memarg0) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) MEMORY_INIT_instr(x, y)]) -- if (v_n =/= 0) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_mem(z, x).BYTES_meminst|) /\ (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_data(z, y).BYTES_datainst|)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(x, y)])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(x, y)])) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), i)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN($proj_byte_0($fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0)))) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) - -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN($proj_byte_0($fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0)))) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_data(z, y).BYTES_datainst|) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, $memarg0)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(MEMORY_INIT_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_null{z : state, ht : heaptype}: - `%~>%`(`%;%`_config(z, [`REF.NULL`_instr(ht)]), [`REF.NULL_ADDR`_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL`_instr(ht)])) - -- wf_instr: `%`(`REF.NULL_ADDR`_instr) + `%~>%`(mk_config_config(z, [REF_NULL_instr(ht)]), [REF_NULL_ADDR_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_instr(ht)])) + -- wf_instr: `%`(REF_NULL_ADDR_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_func{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.FUNC`_instr(x)]), [`REF.FUNC_ADDR`_instr($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) + `%~>%`(mk_config_config(z, [REF_FUNC_instr(x)]), [REF_FUNC_ADDR_instr($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])]) + -- wf_config: `%`(mk_config_config(z, [REF_FUNC_instr(x)])) + -- wf_instr: `%`(REF_FUNC_ADDR_instr($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) -- if ($proj_uN_0(x).0 < |$fun_moduleinst(z).FUNCS_moduleinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.FUNC`_instr(x)])) - -- wf_instr: `%`(`REF.FUNC_ADDR`_instr($fun_moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule ref_test_true{s : store, f : frame, v_ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) + rule ref_test_true{s : store, f : frame, v_ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))]) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)])) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(1)))) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_test_false{s : store, f : frame, v_ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) - -- ~ Step_read_before_ref_test_false: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))]) + -- ~ Step_read_before_ref_test_false: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_TEST_instr(rt)])) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule ref_cast_succeed{s : store, f : frame, v_ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)]), [$instr_ref(v_ref)]) - -- Ref_ok: `%|-%:%`(s, v_ref, $inst_reftype(f.MODULE_frame, rt)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) + rule ref_cast_succeed{s : store, f : frame, v_ref : ref, rt : reftype, var_0 : reftype}: + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)]), [$instr_ref(v_ref)]) + -- Ref_ok: `%|-%:%`(s, v_ref, var_0) + -- wf_reftype: `%`(var_0) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)])) + -- fun_inst_reftype: `%%%`(f.MODULE_frame, rt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_cast_fail{s : store, f : frame, v_ref : ref, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)]), [TRAP_instr]) - -- ~ Step_read_before_ref_cast_fail: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) + `%~>%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)]), [TRAP_instr]) + -- ~ Step_read_before_ref_cast_fail: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [$instr_ref(v_ref) REF_CAST_instr(rt)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule struct_new_default{z : state, x : idx, val_lst : val*, mut_opt_lst : mut?*, zt_lst : storagetype*}: - `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(v_val)*{v_val <- val_lst} ++ [`STRUCT.NEW`_instr(x)]) - -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + `%~>%`(mk_config_config(z, [STRUCT_NEW_DEFAULT_instr(x)]), $instr_val(v_val)*{v_val <- val_lst} ++ [STRUCT_NEW_instr(x)]) + -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (if (!($default_($unpack(zt))) = ?(v_val)))*{v_val <- val_lst, zt <- zt_lst} -- if (|val_lst| = |zt_lst|) -- (if ($default_($unpack(zt)) =/= ?()))*{zt <- zt_lst} - -- (if (!($default_($unpack(zt))) = ?(v_val)))*{v_val <- val_lst, zt <- zt_lst} -- (wf_val: `%`(v_val))*{v_val <- val_lst} - -- wf_config: `%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)])) - -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))}*{zt <- zt_lst} + -- (wf_valtype: `%`($unpack(zt)))*{zt <- zt_lst} + -- wf_config: `%`(mk_config_config(z, [STRUCT_NEW_DEFAULT_instr(x)])) + -- wf_instr: `%`(STRUCT_NEW_instr(x)) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule struct_get_null{z : state, sx_opt : sx?, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `STRUCT.GET`_instr(sx_opt, x, i)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `STRUCT.GET`_instr(sx_opt, x, i)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr STRUCT_GET_instr(sx_opt, x, i)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr STRUCT_GET_instr(sx_opt, x, i)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule struct_get_struct{z : state, a : addr, sx_opt : sx?, x : idx, i : fieldidx, zt_lst : storagetype*, mut_opt_lst : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx_opt, x, i)]), [$instr_val(!($unpackfield_(zt_lst[$proj_uN_0(i).0], sx_opt, $fun_structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) + `%~>%`(mk_config_config(z, [REF_STRUCT_ADDR_instr(a) STRUCT_GET_instr(sx_opt, x, i)]), [$instr_val(!($unpackfield_(zt_lst[$proj_uN_0(i).0], sx_opt, $fun_structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0])))]) + -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_val: `%`(!($unpackfield_(zt_lst[$proj_uN_0(i).0], sx_opt, $fun_structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]))) -- if ($unpackfield_(zt_lst[$proj_uN_0(i).0], sx_opt, $fun_structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0]) =/= ?()) -- if ($proj_uN_0(i).0 < |zt_lst|) -- if ($proj_uN_0(i).0 < |$fun_structinst(z)[a].FIELDS_structinst|) -- if (a < |$fun_structinst(z)|) - -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx_opt, x, i)])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (wf_structinst: `%`(iter))*{iter <- $fun_structinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_STRUCT_ADDR_instr(a) STRUCT_GET_instr(sx_opt, x, i)])) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new_default{z : state, v_n : n, x : idx, v_val : val, mut_opt : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DEFAULT`_instr(x)]), $instr_val(v_val)^v_n{} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if ($default_($unpack(zt)) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DEFAULT_instr(x)]), $instr_val(v_val)^v_n{} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))]) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if (!($default_($unpack(zt))) = ?(v_val)) + -- if ($default_($unpack(zt)) =/= ?()) -- wf_val: `%`(v_val) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DEFAULT`_instr(x)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- (wf_val: `%`(iter))?{iter <- !($default_($unpack(zt)))} + -- wf_valtype: `%`($unpack(zt)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DEFAULT_instr(x)])) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new_elem_oob{z : state, i : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_ELEM_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_ELEM`_instr(x, y)])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new_elem_alloc{z : state, i : num_, v_n : n, x : idx, y : idx, ref_lst : ref*}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_ELEM`_instr(x, y)]), $instr_ref(v_ref)^v_n{v_ref <- ref_lst} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_ELEM_instr(x, y)]), $instr_ref(v_ref)^v_n{v_ref <- ref_lst} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))]) -- if (ref_lst = $fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : v_n]) + -- if ($proj_num__0(i) =/= ?()) -- (wf_ref: `%`(v_ref))*{v_ref <- ref_lst} - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_ELEM`_instr(x, y)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_ELEM_instr(x, y)])) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) + -- if (v_n = |ref_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new_data_oob{z : state, i : num_, v_n : n, x : idx, y : idx, mut_opt : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DATA`_instr(x, y)]), [TRAP_instr]) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + `%~>%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DATA_instr(x, y)]), [TRAP_instr]) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) -- if ($proj_num__0(i) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DATA`_instr(x, y)])) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_new_data_num{z : state, i : num_, v_n : n, x : idx, y : idx, zt : storagetype, c_lst : lit_*, mut_opt : mut?}: - `%~>%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DATA`_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^v_n{c <- c_lst} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) - -- (if ($cunpack(zt) =/= ?()))^v_n{} - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + `%~>%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DATA_instr(x, y)]), $const(!($cunpack(zt)), $cunpacknum_(zt, c))^v_n{c <- c_lst} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))]) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^v_n{c <- c_lst}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if ($zsize(zt) =/= ?()) -- if ($proj_num__0(i) =/= ?()) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^v_n{c <- c_lst}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- (wf_lit_: `%%`(zt, c))*{c <- c_lst} - -- wf_config: `%`(`%;%`_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.NEW_DATA`_instr(x, y)])) - -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- (wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))))^v_n{c <- c_lst} + -- (if ($cunpack(zt) =/= ?()))^v_n{} + -- (wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)))^v_n{c <- c_lst} + -- (wf_byte: `%`(iter))*{iter <- $concatn_(syntax byte, $zbytes_(zt, c)^v_n{c <- c_lst}, (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))} + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)}^v_n{c <- c_lst} + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_NEW_DATA_instr(x, y)])) + -- wf_instr: `%`(ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if (v_n = |c_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_get_null{z : state, i : num_, sx_opt : sx?, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_get_oob{z : state, a : addr, i : num_, sx_opt : sx?, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)]), [TRAP_instr]) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_get_array{z : state, a : addr, i : num_, sx_opt : sx?, x : idx, zt : storagetype, mut_opt : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)]), [$instr_val(!($unpackfield_(zt, sx_opt, $fun_arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)]), [$instr_val(!($unpackfield_(zt, sx_opt, $fun_arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0])))]) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- wf_val: `%`(!($unpackfield_(zt, sx_opt, $fun_arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]))) -- if ($unpackfield_(zt, sx_opt, $fun_arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0]) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if (a < |$fun_arrayinst(z)|) -- if ($proj_num__0(i) =/= ?()) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) ARRAY_GET_instr(sx_opt, x)])) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_len_null{z : state}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `ARRAY.LEN`_instr]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr `ARRAY.LEN`_instr])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr ARRAY_LEN_instr]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr ARRAY_LEN_instr])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_len_array{z : state, a : addr}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$fun_arrayinst(z)[a].FIELDS_arrayinst|)))]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) ARRAY_LEN_instr]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(|$fun_arrayinst(z)[a].FIELDS_arrayinst|)))]) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) ARRAY_LEN_instr])) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(|$fun_arrayinst(z)[a].FIELDS_arrayinst|)))) -- if (a < |$fun_arrayinst(z)|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) `ARRAY.LEN`_instr])) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(|$fun_arrayinst(z)[a].FIELDS_arrayinst|)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_fill_null{z : state, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_fill_oob{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_fill_zero{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)]), []) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)]), []) + -- ~ Step_read_before_array_fill_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_fill_succ{z : state, a : addr, i : num_, v_val : val, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.FILL`_instr(x)]) - -- if ($proj_num__0(i) =/= ?()) - -- if (v_n =/= 0) - -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.FILL`_instr(x)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)]), [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x) REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_FILL_instr(x)]) + -- ~ Step_read_before_array_fill_succ: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_FILL_instr(x)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) + -- wf_instr: `%`(ARRAY_SET_instr(x)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_FILL_instr(x)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_null1{z : state, i_1 : num_, v_ref : ref, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(v_ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_1) $instr_ref(v_ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i_1) $instr_ref(v_ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i_1) $instr_ref(v_ref) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_null2{z : state, v_ref : ref, i_1 : num_, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr(I32_numtype, i_1) `REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + `%~>%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr(I32_numtype, i_1) REF_NULL_ADDR_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr(I32_numtype, i_1) REF_NULL_ADDR_instr CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob1{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) -- if ($proj_num__0(i_1) =/= ?()) -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) > |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_oob2{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) -- if ($proj_num__0(i_2) =/= ?()) -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) > |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_zero{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), []) - -- if ($proj_num__0(i_2) =/= ?()) - -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if ($proj_num__0(i_1) =/= ?()) - -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), []) + -- ~ Step_read_before_array_copy_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_le{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx, sx_opt : sx?, mut_opt : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) `ARRAY.GET`_instr(sx_opt, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) ARRAY_GET_instr(sx_opt, x_2) ARRAY_SET_instr(x_1) REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1)))) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_COPY_instr(x_1, x_2)]) + -- ~ Step_read_before_array_copy_le: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !($fun_sx(zt_2)))) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) - -- if (v_n =/= 0) - -- if (a_2 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) <= |$fun_arrayinst(z)[a_2].FIELDS_arrayinst|) - -- if (a_1 < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) <= |$fun_arrayinst(z)[a_1].FIELDS_arrayinst|) - -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) -- if ($fun_sx(zt_2) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !($fun_sx(zt_2)))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_2)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx_opt, x_2)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) + -- wf_instr: `%`(ARRAY_GET_instr(sx_opt, x_2)) + -- wf_instr: `%`(ARRAY_SET_instr(x_1)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i_2))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_COPY_instr(x_1, x_2)) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_copy_gt{z : state, a_1 : addr, i_1 : num_, a_2 : addr, i_2 : num_, v_n : n, x_1 : idx, x_2 : idx, sx_opt : sx?, mut_opt : mut?, zt_2 : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)]), [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.GET`_instr(sx_opt, x_2) `ARRAY.SET`_instr(x_1) `REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.COPY`_instr(x_1, x_2)]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)]), [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_GET_instr(sx_opt, x_2) ARRAY_SET_instr(x_1) REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_COPY_instr(x_1, x_2)]) + -- ~ Step_read_before_array_copy_gt: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) + -- if (sx_opt = !($fun_sx(zt_2))) + -- if ($fun_sx(zt_2) =/= ?()) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a_1) CONST_instr(I32_numtype, i_1) REF_ARRAY_ADDR_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_COPY_instr(x_1, x_2)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_1)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a_2)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- if ($proj_num__0(i_2) =/= ?()) - -- ~ Step_read_before_array_copy_gt: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- Expand: `%~~%`($fun_type(z, x_2), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) - -- if ($fun_sx(zt_2) =/= ?()) - -- if (sx_opt = !($fun_sx(zt_2))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, i_1) `REF.ARRAY_ADDR`_instr(a_2) CONST_instr(I32_numtype, i_2) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.COPY`_instr(x_1, x_2)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_1)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_1))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((($proj_uN_0(!($proj_num__0(i_2))).0 + v_n) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.GET`_instr(sx_opt, x_2)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x_1)) + -- wf_instr: `%`(ARRAY_GET_instr(sx_opt, x_2)) + -- wf_instr: `%`(ARRAY_SET_instr(x_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_1)) -- wf_instr: `%`(CONST_instr(I32_numtype, i_2)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.COPY`_instr(x_1, x_2)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_2))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_COPY_instr(x_1, x_2)) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt_2))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_elem_null{z : state, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_elem_oob1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_elem_oob2{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [TRAP_instr]) - -- if ($proj_num__0(j) =/= ?()) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)]), [TRAP_instr]) -- if (($proj_uN_0(!($proj_num__0(j))).0 + v_n) > |$fun_elem(z, y).REFS_eleminst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- if ($proj_num__0(j) =/= ?()) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_elem_zero{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)]), []) - -- if ($proj_num__0(j) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_elem(z, y).REFS_eleminst|) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)]), []) + -- ~ Step_read_before_array_init_elem_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_elem_succ{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx, v_ref : ref}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_ref(v_ref) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_ELEM`_instr(x, y)]) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(j) =/= ?()) - -- if (v_n =/= 0) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + v_n) <= |$fun_elem(z, y).REFS_eleminst|) - -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) <= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_elem(z, y).REFS_eleminst|) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)]), [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_ref(v_ref) ARRAY_SET_instr(x) REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_INIT_ELEM_instr(x, y)]) + -- ~ Step_read_before_array_init_elem_succ: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) -- if (v_ref = $fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) + -- if ($proj_uN_0(!($proj_num__0(j))).0 < |$fun_elem(z, y).REFS_eleminst|) + -- if ($proj_num__0(j) =/= ?()) -- wf_ref: `%`(v_ref) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_ELEM`_instr(x, y)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) + -- wf_eleminst: `%`($fun_elem(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_ELEM_instr(x, y)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.INIT_ELEM`_instr(x, y)) + -- wf_instr: `%`(ARRAY_SET_instr(x)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + 1))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_INIT_ELEM_instr(x, y)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_null{z : state, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)]), [TRAP_instr]) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob1{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)]), [TRAP_instr]) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_oob2{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx, mut_opt : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [TRAP_instr]) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)]), [TRAP_instr]) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- wf_instr: `%`(TRAP_instr) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_zero{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), []) - -- ~ Step_read_before_array_init_data_zero: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)]), []) + -- ~ Step_read_before_array_init_data_zero: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) -- if (v_n = 0) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_init_data_num{z : state, a : addr, i : num_, j : num_, v_n : n, x : idx, y : idx, zt : storagetype, c : lit_, mut_opt : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) `ARRAY.SET`_instr(x) `REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) `ARRAY.INIT_DATA`_instr(x, y)]) - -- if ($cunpack(zt) =/= ?()) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)]), [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $const(!($cunpack(zt)), $cunpacknum_(zt, c)) ARRAY_SET_instr(x) REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1)))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat))))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ARRAY_INIT_DATA_instr(x, y)]) + -- ~ Step_read_before_array_init_data_num: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- if ($zbytes_(zt, c) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- if ($proj_num__0(j) =/= ?()) -- if ($zsize(zt) =/= ?()) - -- ~ Step_read_before_array_init_data_num: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if ($zbytes_(zt, c) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) -- wf_lit_: `%%`(zt, c) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `ARRAY.INIT_DATA`_instr(x, y)])) - -- wf_instr: `%`(`REF.ARRAY_ADDR`_instr(a)) + -- wf_instr: `%`($const(!($cunpack(zt)), $cunpacknum_(zt, c))) + -- if ($cunpack(zt) =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!($cunpack(zt))), $cunpacknum_(zt, c)) + -- (wf_byte: `%`(iter))*{iter <- $zbytes_(zt, c)} + -- wf_datainst: `%`($fun_data(z, y)) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) CONST_instr(I32_numtype, j) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) ARRAY_INIT_DATA_instr(x, y)])) + -- wf_instr: `%`(REF_ARRAY_ADDR_instr(a)) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) - -- wf_instr: `%`(`ARRAY.SET`_instr(x)) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) - -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_instr: `%`(ARRAY_SET_instr(x)) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(i))).0 + 1))))) + -- if ($proj_num__0(i) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(($proj_uN_0(!($proj_num__0(j))).0 + (((!($zsize(zt)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)))))) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN((((v_n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(ARRAY_INIT_DATA_instr(x, y)) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -14578,269 +18872,299 @@ rec { relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:13.1-15.34 rule pure{z : state, instr_lst : instr*, instr'_lst : instr*}: - `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z, instr'_lst)) + `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z, instr'_lst)) -- Step_pure: `%~>%`(instr_lst, instr'_lst) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z, instr'_lst)) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z, instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:17.1-19.37 rule read{z : state, instr_lst : instr*, instr'_lst : instr*}: - `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z, instr'_lst)) - -- Step_read: `%~>%`(`%;%`_config(z, instr_lst), instr'_lst) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z, instr'_lst)) + `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z, instr'_lst)) + -- Step_read: `%~>%`(mk_config_config(z, instr_lst), instr'_lst) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z, instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:32.1-35.41 rule ctxt_instrs{z : state, val_lst : val*, instr_lst : instr*, instr_1_lst : instr*, z' : state, instr'_lst : instr*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ instr_lst ++ instr_1_lst), `%;%`_config(z', $instr_val(v_val)*{v_val <- val_lst} ++ instr'_lst ++ instr_1_lst)) - -- Step: `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z', instr'_lst)) + `%~>%`(mk_config_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ instr_lst ++ instr_1_lst), mk_config_config(z', $instr_val(v_val)*{v_val <- val_lst} ++ instr'_lst ++ instr_1_lst)) + -- Step: `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z', instr'_lst)) -- if ((val_lst =/= []) \/ (instr_1_lst =/= [])) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ instr_lst ++ instr_1_lst)) - -- wf_config: `%`(`%;%`_config(z', $instr_val(v_val)*{v_val <- val_lst} ++ instr'_lst ++ instr_1_lst)) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z', instr'_lst)) + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)*{v_val <- val_lst} ++ instr_lst ++ instr_1_lst)) + -- wf_config: `%`(mk_config_config(z', $instr_val(v_val)*{v_val <- val_lst} ++ instr'_lst ++ instr_1_lst)) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z', instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:37.1-39.36 rule ctxt_label{z : state, v_n : n, instr_0_lst : instr*, instr_lst : instr*, z' : state, instr'_lst : instr*}: - `%~>%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr_lst)]), `%;%`_config(z', [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr'_lst)])) - -- Step: `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z', instr'_lst)) - -- wf_config: `%`(`%;%`_config(z, [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr_lst)])) - -- wf_config: `%`(`%;%`_config(z', [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr'_lst)])) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z', instr'_lst)) + `%~>%`(mk_config_config(z, [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr_lst)]), mk_config_config(z', [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr'_lst)])) + -- Step: `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z', instr'_lst)) + -- wf_config: `%`(mk_config_config(z, [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr_lst)])) + -- wf_config: `%`(mk_config_config(z', [`LABEL_%{%}%`_instr(v_n, instr_0_lst, instr'_lst)])) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z', instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:41.1-43.36 rule ctxt_handler{z : state, v_n : n, catch_lst : catch*, instr_lst : instr*, z' : state, instr'_lst : instr*}: - `%~>%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst)]), `%;%`_config(z', [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr'_lst)])) - -- Step: `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z', instr'_lst)) - -- wf_config: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst)])) - -- wf_config: `%`(`%;%`_config(z', [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr'_lst)])) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z', instr'_lst)) + `%~>%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst)]), mk_config_config(z', [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr'_lst)])) + -- Step: `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z', instr'_lst)) + -- wf_config: `%`(mk_config_config(z, [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst)])) + -- wf_config: `%`(mk_config_config(z', [`HANDLER_%{%}%`_instr(v_n, catch_lst, instr'_lst)])) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z', instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:45.1-47.45 rule ctxt_frame{s : store, f : frame, v_n : n, f' : frame, instr_lst : instr*, s' : store, f'' : frame, instr'_lst : instr*}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [`FRAME_%{%}%`_instr(v_n, f', instr_lst)]), `%;%`_config(`%;%`_state(s', f), [`FRAME_%{%}%`_instr(v_n, f'', instr'_lst)])) - -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr_lst), `%;%`_config(`%;%`_state(s', f''), instr'_lst)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [`FRAME_%{%}%`_instr(v_n, f', instr_lst)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s', f), [`FRAME_%{%}%`_instr(v_n, f'', instr'_lst)])) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f'), instr_lst)) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s', f''), instr'_lst)) + `%~>%`(mk_config_config(mk_state_state(s, f), [`FRAME_%{%}%`_instr(v_n, f', instr_lst)]), mk_config_config(mk_state_state(s', f), [`FRAME_%{%}%`_instr(v_n, f'', instr'_lst)])) + -- Step: `%~>%`(mk_config_config(mk_state_state(s, f'), instr_lst), mk_config_config(mk_state_state(s', f''), instr'_lst)) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), [`FRAME_%{%}%`_instr(v_n, f', instr_lst)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s', f), [`FRAME_%{%}%`_instr(v_n, f'', instr'_lst)])) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f'), instr_lst)) + -- wf_config: `%`(mk_config_config(mk_state_state(s', f''), instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:227.1-231.49 rule throw{z : state, v_n : n, val_lst : val*, x : idx, exn : exninst, a : addr, t_lst : valtype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)]), `%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)]), mk_config_config($add_exninst(z, [exn]), [REF_EXN_ADDR_instr(a) THROW_REF_instr])) + -- Expand: `%~~%`(!($as_deftype($fun_tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- if ($as_deftype($fun_tag(z, x).TYPE_taginst) =/= ?()) - -- Expand: `%~~%`(!($as_deftype($fun_tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) -- if (a = |$fun_exninst(z)|) - -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) -- if (exn = {TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)])) - -- wf_config: `%`(`%;%`_config($add_exninst(z, [exn]), [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |$fun_tagaddr(z)|) + -- wf_taginst: `%`($fun_tag(z, x)) + -- (wf_exninst: `%`(iter))*{iter <- $fun_exninst(z)} + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)])) + -- wf_config: `%`(mk_config_config($add_exninst(z, [exn]), [REF_EXN_ADDR_instr(a) THROW_REF_instr])) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- wf_exninst: `%`({TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) + -- if (v_n = |val_lst|) + -- if (v_n = |t_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:305.1-306.56 rule local_set{z : state, v_val : val, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_val(v_val) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, v_val), [])) - -- wf_config: `%`(`%;%`_config(z, [$instr_val(v_val) `LOCAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_local(z, x, v_val), [])) + `%~>%`(mk_config_config(z, [$instr_val(v_val) LOCAL_SET_instr(x)]), mk_config_config($with_local(z, x, v_val), [])) + -- wf_config: `%`(mk_config_config(z, [$instr_val(v_val) LOCAL_SET_instr(x)])) + -- wf_config: `%`(mk_config_config($with_local(z, x, v_val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:318.1-319.58 rule global_set{z : state, v_val : val, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_val(v_val) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, v_val), [])) - -- wf_config: `%`(`%;%`_config(z, [$instr_val(v_val) `GLOBAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_global(z, x, v_val), [])) + `%~>%`(mk_config_config(z, [$instr_val(v_val) GLOBAL_SET_instr(x)]), mk_config_config($with_global(z, x, v_val), [])) + -- wf_config: `%`(mk_config_config(z, [$instr_val(v_val) GLOBAL_SET_instr(x)])) + -- wf_config: `%`(mk_config_config($with_global(z, x, v_val), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:332.1-334.33 rule table_set_oob{z : state, at : addrtype, i : num_, v_ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) TABLE_SET_instr(x)]), mk_config_config(z, [TRAP_instr])) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) `TABLE.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) TABLE_SET_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.32 rule table_set_val{z : state, at : addrtype, i : num_, v_ref : ref, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) `TABLE.SET`_instr(x)]), `%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, v_ref), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) TABLE_SET_instr(x)]), mk_config_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, v_ref), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$fun_table(z, x).REFS_tableinst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) `TABLE.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, v_ref), [])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) TABLE_SET_instr(x)])) + -- wf_config: `%`(mk_config_config($with_table(z, x, $proj_uN_0(!($proj_num__0(i))).0, v_ref), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:347.1-350.46 - rule table_grow_succeed{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx, ti : tableinst}: - `%~>%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.GROW`_instr(x)]), `%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$fun_table(z, x).REFS_tableinst|)))])) - -- if ($growtable($fun_table(z, x), v_n, v_ref) =/= ?()) - -- if (ti = !($growtable($fun_table(z, x), v_n, v_ref))) - -- wf_config: `%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$fun_table(z, x).REFS_tableinst|)))])) + rule table_grow_succeed{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx, ti : tableinst, var_0 : tableinst?}: + `%~>%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_GROW_instr(x)]), mk_config_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(|$fun_table(z, x).REFS_tableinst|)))])) + -- if (ti = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_tableinst: `%`(!(var_0)) + -- wf_tableinst: `%`($fun_table(z, x)) + -- wf_config: `%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_GROW_instr(x)])) + -- wf_config: `%`(mk_config_config($with_tableinst(z, x, ti), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(|$fun_table(z, x).REFS_tableinst|)))])) + -- fun_growtable: `%%%%`($fun_table(z, x), v_n, v_ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:352.1-353.87 - rule table_grow_fail{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + rule table_grow_fail{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx, var_0 : nat}: + `%~>%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_GROW_instr(x)]), mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(var_0)))])) + -- wf_config: `%`(mk_config_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) TABLE_GROW_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:413.1-414.51 rule elem_drop{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config($with_elem(z, x, []), [])) - -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_elem(z, x, []), [])) + `%~>%`(mk_config_config(z, [ELEM_DROP_instr(x)]), mk_config_config($with_elem(z, x, []), [])) + -- wf_config: `%`(mk_config_config(z, [ELEM_DROP_instr(x)])) + -- wf_config: `%`(mk_config_config($with_elem(z, x, []), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:497.1-500.60 rule store_num_oob{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), mk_config_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:502.1-506.29 rule store_num_val{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, b_lst : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) -- if (b_lst = $nbytes_(nt, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- (wf_byte: `%`(iter))*{iter <- $nbytes_(nt, c)} + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- wf_config: `%`(mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($size(nt) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:508.1-511.52 rule store_pack_oob{z : state, at : addrtype, i : num_, v_Inn : Inn, c : num_, v_n : n, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_n)))), x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_n)))), x, ao)]), mk_config_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_n)))), x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_n)))), x, ao)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:513.1-517.52 rule store_pack_val{z : state, at : addrtype, i : num_, v_Inn : Inn, c : num_, v_n : n, x : idx, ao : memarg, b_lst : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_n)))), x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($proj_num__0(c) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_n)))), x, ao)]), mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) -- if (b_lst = $ibytes_(v_n, $wrap__($size($numtype_addrtype(v_Inn)), v_n, !($proj_num__0(c))))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, `%`_storeop_Inn(`%`_sz(v_n)))), x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- if ($proj_num__0(c) =/= ?()) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_n, $wrap__($size($numtype_addrtype(v_Inn)), v_n, !($proj_num__0(c))))} + -- wf_uN: `%%`(v_n, $wrap__($size($numtype_addrtype(v_Inn)), v_n, !($proj_num__0(c)))) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr($numtype_addrtype(v_Inn), c) STORE_instr($numtype_addrtype(v_Inn), ?(mk_storeop__0_storeop_(v_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(v_n)))), x, ao)])) + -- wf_config: `%`(mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_n : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:519.1-522.63 rule vstore_oob{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), mk_config_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:524.1-527.31 rule vstore_val{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, b_lst : byte*}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) -- if (b_lst = $vbytes_(V128_vectype, c)) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- (wf_byte: `%`(iter))*{iter <- $vbytes_(V128_vectype, c)} + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- wf_config: `%`(mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), ((($vsize(V128_vectype) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- if ($proj_num__0(i) =/= ?()) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:530.1-533.50 rule vstore_lane_oob{z : state, at : addrtype, i : num_, c : vec_, v_N : N, x : idx, ao : memarg, j : laneidx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)]), `%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)]), mk_config_config(z, [TRAP_instr])) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + v_N) > |$fun_mem(z, x).BYTES_meminst|) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:535.1-540.49 rule vstore_lane_val{z : state, at : addrtype, i : num_, c : vec_, v_N : N, x : idx, ao : memarg, j : laneidx, b_lst : byte*, v_Jnn : Jnn, v_M : M}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)]), `%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) - -- if ($proj_num__0(i) =/= ?()) + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)]), mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) -- if (v_N = $jsize(v_Jnn)) -- if ((v_M : nat <:> rat) = ((128 : nat <:> rat) / (v_N : nat <:> rat))) - -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c)[$proj_uN_0(j).0]) =/= ?()) - -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c)|) - -- if (b_lst = $ibytes_(v_N, `%`_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c)[$proj_uN_0(j).0]))).0))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(v_N), x, ao, j)])) - -- wf_config: `%`(`%;%`_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) - -- wf_uN: `%%`(v_N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c)[$proj_uN_0(j).0]))).0)) + -- if (b_lst = $ibytes_(v_N, mk_uN_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c)[$proj_uN_0(j).0]))).0))) + -- if ($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c)[$proj_uN_0(j).0]) =/= ?()) + -- if ($proj_uN_0(j).0 < |$lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c)|) + -- (wf_byte: `%`(iter))*{iter <- $ibytes_(v_N, mk_uN_iN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c)[$proj_uN_0(j).0]))).0))} + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, mk_sz_sz(v_N), x, ao, j)])) + -- wf_config: `%`(mk_config_config($with_mem(z, x, ($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0), (((v_N : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat), b_lst), [])) + -- if ($proj_num__0(i) =/= ?()) + -- wf_uN: `%%`(v_N, mk_uN_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), mk_dim_dim(v_M)), c)[$proj_uN_0(j).0]))).0)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:549.1-552.37 - rule memory_grow_succeed{z : state, at : addrtype, v_n : n, x : idx, mi : meminst}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.GROW`_instr(x)]), `%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$fun_mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) - -- if ($growmem($fun_mem(z, x), v_n) =/= ?()) - -- if (mi = !($growmem($fun_mem(z, x), v_n))) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$fun_mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + rule memory_grow_succeed{z : state, at : addrtype, v_n : n, x : idx, mi : meminst, var_0 : meminst?}: + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_GROW_instr(x)]), mk_config_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((|$fun_mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- if (mi = !(var_0)) + -- if (var_0 =/= ?()) + -- wf_meminst: `%`(!(var_0)) + -- wf_meminst: `%`($fun_mem(z, x)) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_GROW_instr(x)])) + -- wf_config: `%`(mk_config_config($with_meminst(z, x, mi), [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN((((|$fun_mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- fun_growmem: `%%%`($fun_mem(z, x), v_n, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:554.1-555.84 - rule memory_grow_fail{z : state, at : addrtype, v_n : n, x : idx}: - `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.GROW`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN($inv_signed_($size($numtype_addrtype(at)), - (1 : nat <:> int)))))])) + rule memory_grow_fail{z : state, at : addrtype, v_n : n, x : idx, var_0 : nat}: + `%~>%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_GROW_instr(x)]), mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(var_0)))])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(v_n))) MEMORY_GROW_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, mk_uN_uN(var_0)))])) + -- fun_inv_signed_: `%%%`($size($numtype_addrtype(at)), - (1 : nat <:> int), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:615.1-616.51 rule data_drop{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config($with_data(z, x, []), [])) - -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_data(z, x, []), [])) + `%~>%`(mk_config_config(z, [DATA_DROP_instr(x)]), mk_config_config($with_data(z, x, []), [])) + -- wf_config: `%`(mk_config_config(z, [DATA_DROP_instr(x)])) + -- wf_config: `%`(mk_config_config($with_data(z, x, []), [])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:692.1-696.65 rule struct_new{z : state, v_n : n, val_lst : val*, x : idx, si : structinst, a : addr, mut_opt_lst : mut?*, zt_lst : storagetype*}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) - -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)^v_n{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [STRUCT_NEW_instr(x)]), mk_config_config($add_structinst(z, [si]), [REF_STRUCT_ADDR_instr(a)])) + -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)^v_n{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- if (a = |$fun_structinst(z)|) - -- (if ($packfield_(zt, v_val) =/= ?()))^v_n{v_val <- val_lst, zt <- zt_lst} -- if (si = {TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst, zt <- zt_lst}}) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`STRUCT.NEW`_instr(x)])) - -- wf_config: `%`(`%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)^v_n{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (if ($packfield_(zt, v_val) =/= ?()))^v_n{v_val <- val_lst, zt <- zt_lst} + -- (wf_structinst: `%`(iter))*{iter <- $fun_structinst(z)} + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [STRUCT_NEW_instr(x)])) + -- wf_config: `%`(mk_config_config($add_structinst(z, [si]), [REF_STRUCT_ADDR_instr(a)])) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)^v_n{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- wf_structinst: `%`({TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst, zt <- zt_lst}}) + -- if (v_n = |val_lst|) + -- if (v_n = |mut_opt_lst|) + -- if (v_n = |zt_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:713.1-714.55 rule struct_set_null{z : state, v_val : val, x : idx, i : fieldidx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(v_val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr $instr_val(v_val) `STRUCT.SET`_instr(x, i)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr $instr_val(v_val) STRUCT_SET_instr(x, i)]), mk_config_config(z, [TRAP_instr])) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr $instr_val(v_val) STRUCT_SET_instr(x, i)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:716.1-719.46 rule struct_set_struct{z : state, a : addr, v_val : val, x : idx, i : fieldidx, zt_lst : storagetype*, mut_opt_lst : mut?*}: - `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(v_val) `STRUCT.SET`_instr(x, i)]), `%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt_lst[$proj_uN_0(i).0], v_val))), [])) + `%~>%`(mk_config_config(z, [REF_STRUCT_ADDR_instr(a) $instr_val(v_val) STRUCT_SET_instr(x, i)]), mk_config_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt_lst[$proj_uN_0(i).0], v_val))), [])) + -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_config: `%`(mk_config_config(z, [REF_STRUCT_ADDR_instr(a) $instr_val(v_val) STRUCT_SET_instr(x, i)])) + -- wf_config: `%`(mk_config_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt_lst[$proj_uN_0(i).0], v_val))), [])) -- if ($packfield_(zt_lst[$proj_uN_0(i).0], v_val) =/= ?()) -- if ($proj_uN_0(i).0 < |zt_lst|) - -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) - -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(v_val) `STRUCT.SET`_instr(x, i)])) - -- wf_config: `%`(`%;%`_config($with_struct(z, a, $proj_uN_0(i).0, !($packfield_(zt_lst[$proj_uN_0(i).0], v_val))), [])) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:732.1-737.65 rule array_new_fixed{z : state, v_n : n, val_lst : val*, x : idx, ai : arrayinst, a : addr, mut_opt : mut?, zt : storagetype}: - `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]), `%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- (if ($packfield_(zt, v_val) =/= ?()))^v_n{v_val <- val_lst} + `%~>%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))]), mk_config_config($add_arrayinst(z, [ai]), [REF_ARRAY_ADDR_instr(a)])) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- if ((a = |$fun_arrayinst(z)|) /\ (ai = {TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst}})) - -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))])) - -- wf_config: `%`(`%;%`_config($add_arrayinst(z, [ai]), [`REF.ARRAY_ADDR`_instr(a)])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- (if ($packfield_(zt, v_val) =/= ?()))^v_n{v_val <- val_lst} + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n))])) + -- wf_config: `%`(mk_config_config($add_arrayinst(z, [ai]), [REF_ARRAY_ADDR_instr(a)])) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- wf_arrayinst: `%`({TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst}}) + -- if (v_n = |val_lst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:777.1-778.66 rule array_set_null{z : state, i : num_, v_val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) - -- wf_config: `%`(`%;%`_config(z, [`REF.NULL_ADDR`_instr CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + `%~>%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)]), mk_config_config(z, [TRAP_instr])) + -- wf_config: `%`(mk_config_config(z, [REF_NULL_ADDR_instr CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:780.1-782.39 rule array_set_oob{z : state, a : addr, i : num_, v_val : val, x : idx}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)]), mk_config_config(z, [TRAP_instr])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$fun_arrayinst(z)|) - -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- (wf_arrayinst: `%`(iter))*{iter <- $fun_arrayinst(z)} + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)])) + -- wf_config: `%`(mk_config_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:784.1-787.44 rule array_set_array{z : state, a : addr, i : num_, v_val : val, x : idx, zt : storagetype, mut_opt : mut?}: - `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)]), `%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, v_val))), [])) + `%~>%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)]), mk_config_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, v_val))), [])) + -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) + -- wf_config: `%`(mk_config_config(z, [REF_ARRAY_ADDR_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) ARRAY_SET_instr(x)])) + -- wf_config: `%`(mk_config_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, v_val))), [])) -- if ($proj_num__0(i) =/= ?()) -- if ($packfield_(zt, v_val) =/= ?()) - -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_array(z, a, $proj_uN_0(!($proj_num__0(i))).0, !($packfield_(zt, v_val))), [])) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) } ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14850,17 +19174,17 @@ rec { relation Steps: `%~>*%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:21.1-22.26 rule refl{z : state, instr_lst : instr*}: - `%~>*%`(`%;%`_config(z, instr_lst), `%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) + `%~>*%`(mk_config_config(z, instr_lst), mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z, instr_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:24.1-27.44 rule trans{z : state, instr_lst : instr*, z'' : state, instr''_lst : instr*, z' : state, instr'_lst : instr*}: - `%~>*%`(`%;%`_config(z, instr_lst), `%;%`_config(z'', instr''_lst)) - -- Step: `%~>%`(`%;%`_config(z, instr_lst), `%;%`_config(z', instr'_lst)) - -- Steps: `%~>*%`(`%;%`_config(z', instr'_lst), `%;%`_config(z'', instr''_lst)) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z'', instr''_lst)) - -- wf_config: `%`(`%;%`_config(z', instr'_lst)) + `%~>*%`(mk_config_config(z, instr_lst), mk_config_config(z'', instr''_lst)) + -- Step: `%~>%`(mk_config_config(z, instr_lst), mk_config_config(z', instr'_lst)) + -- Steps: `%~>*%`(mk_config_config(z', instr'_lst), mk_config_config(z'', instr''_lst)) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z'', instr''_lst)) + -- wf_config: `%`(mk_config_config(z', instr'_lst)) } ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14868,190 +19192,426 @@ relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule mk_Eval_expr{z : state, instr_lst : instr*, z' : state, val_lst : val*}: `%;%~>*%;%`(z, instr_lst, z', val_lst) - -- Steps: `%~>*%`(`%;%`_config(z, instr_lst), `%;%`_config(z', $instr_val(v_val)*{v_val <- val_lst})) - -- wf_config: `%`(`%;%`_config(z, instr_lst)) - -- wf_config: `%`(`%;%`_config(z', $instr_val(v_val)*{v_val <- val_lst})) + -- Steps: `%~>*%`(mk_config_config(z, instr_lst), mk_config_config(z', $instr_val(v_val)*{v_val <- val_lst})) + -- wf_config: `%`(mk_config_config(z, instr_lst)) + -- wf_config: `%`(mk_config_config(z', $instr_val(v_val)*{v_val <- val_lst})) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.1-7.63 -def $alloctypes(var_0 : type*) : deftype* - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:8.1-8.27 - def $alloctypes([]) = [] - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:9.1-13.24 - def $alloctypes{type'_lst : type*, v_type : type, deftype_lst : deftype*, x : uN}(type'_lst ++ [v_type]) = deftype'_lst ++ deftype_lst - -- let{deftype'_lst : deftype*} deftype'_lst = $alloctypes(type'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 +relation fun_alloctypes: `%%`(type*, deftype*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 + rule fun_alloctypes_case_1{type'_lst : type*, v_type : type, deftype_lst : deftype*, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'_lst ++ [v_type], deftype'_lst ++ deftype_lst) + -- let{deftype'_lst : deftype*} deftype'_lst = var_0 -- let{v_rectype : rectype} TYPE_type(v_rectype) = v_type - -- if (deftype_lst = $subst_all_deftypes($rolldt(x, v_rectype), $typeuse_deftype(deftype'#2)*{deftype'#2 <- deftype'_lst})) + -- if (deftype_lst = var_1) -- if ($proj_uN_0(x).0 = |deftype'_lst|) -- wf_uN: `%%`(32, x) + -- fun_rolldt: `%%%`(x, v_rectype, var_2) + -- fun_subst_all_deftypes: `%%%`(var_2, $typeuse_deftype(deftype'_2)*{deftype'_2 <- deftype'_lst}, var_1) + -- fun_alloctypes: `%%`(type'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_alloctag: `%%%`(store, tagtype, (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_alloctag_case_0{s : store, v_tagtype : typeuse, v_taginst : taginst}: + `%%%`(s, v_tagtype, (s +++ {TAGS [v_taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|)) + -- if (v_taginst = {TYPE v_tagtype}) + -- wf_taginst: `%`({TYPE v_tagtype}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctag_is_wf: `%%%`(v_store : store, v_tagtype : tagtype, ret_val : (store, tagaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule alloctag_is_wf_0{v_store : store, v_tagtype : tagtype, ret_val : (store, tagaddr), var_0 : (store, tagaddr)}: + `%%%`(v_store, v_tagtype, ret_val) + -- wf_store: `%`(v_store) + -- wf_typeuse: `%`(v_tagtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctag: `%%%`(v_store, v_tagtype, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule fun_alloctags_case_1{s : store, v_tagtype : typeuse, tagtype'_lst : tagtype*, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [v_tagtype] ++ tagtype'_lst, (s_2, [ja] ++ ja'_lst)) + -- let{ja : tagaddr, s_1 : store} (s_1, ja) = var_0 + -- let{s_2 : store, ja'_lst : tagaddr*} (s_2, ja'_lst) = var_1 + -- fun_alloctags: `%%%`(s_1, tagtype'_lst, var_1) + -- fun_alloctag: `%%%`(s, v_tagtype, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 +relation alloctags_is_wf: `%%%`(v_store : store, var_0 : tagtype*, ret_val : (store, tagaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 + rule alloctags_is_wf_0{v_store : store, var_0 : tagtype*, ret_val : (store, tagaddr*), var_1 : (store, tagaddr*)}: + `%%%`(v_store, var_0, ret_val) + -- wf_store: `%`(v_store) + -- (wf_typeuse: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_alloctags: `%%%`(v_store, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocglobal: `%%%%`(store, globaltype, val, (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocglobal_case_0{s : store, v_globaltype : globaltype, v_val : val, v_globalinst : globalinst}: + `%%%%`(s, v_globaltype, v_val, (s +++ {TAGS [], GLOBALS [v_globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|)) + -- if (v_globalinst = {TYPE v_globaltype, VALUE v_val}) + -- wf_globalinst: `%`({TYPE v_globaltype, VALUE v_val}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocglobal_is_wf: `%%%%`(v_store : store, v_globaltype : globaltype, v_val : val, ret_val : (store, globaladdr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocglobal_is_wf_0{v_store : store, v_globaltype : globaltype, v_val : val, ret_val : (store, globaladdr), var_0 : (store, globaladdr)}: + `%%%%`(v_store, v_globaltype, v_val, ret_val) + -- wf_store: `%`(v_store) + -- wf_globaltype: `%`(v_globaltype) + -- wf_val: `%`(v_val) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobal: `%%%%`(v_store, v_globaltype, v_val, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation fun_allocglobals: `%%%%`(store, globaltype*, val*, (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule fun_allocglobals_case_1{s : store, v_globaltype : globaltype, globaltype'_lst : globaltype*, v_val : val, val'_lst : val*, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: + `%%%%`(s, [v_globaltype] ++ globaltype'_lst, [v_val] ++ val'_lst, (s_2, [ga] ++ ga'_lst)) + -- let{ga : globaladdr, s_1 : store} (s_1, ga) = var_0 + -- let{s_2 : store, ga'_lst : globaladdr*} (s_2, ga'_lst) = var_1 + -- fun_allocglobals: `%%%%`(s_1, globaltype'_lst, val'_lst, var_1) + -- fun_allocglobal: `%%%%`(s, v_globaltype, v_val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 +relation allocglobals_is_wf: `%%%%`(v_store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.6-31.19 + rule allocglobals_is_wf_0{v_store : store, var_0 : globaltype*, var_1 : val*, ret_val : (store, globaladdr*), var_2 : (store, globaladdr*)}: + `%%%%`(v_store, var_0, var_1, ret_val) + -- wf_store: `%`(v_store) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocglobals: `%%%%`(v_store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(v_store : store, v_tagtype : tagtype) : (store, tagaddr) +relation fun_allocmem: `%%%`(store, memtype, (store, memaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocmem_case_0{s : store, at : addrtype, i : uN, j_opt : u64?, v_meminst : meminst}: + `%%%`(s, `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), (s +++ {TAGS [], GLOBALS [], MEMS [v_meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|)) + -- if (v_meminst = {TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES mk_byte_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(i, j_opt)), BYTES mk_byte_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmem_is_wf: `%%%`(v_store : store, v_memtype : memtype, ret_val : (store, memaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctag{s : store, v_tagtype : typeuse, v_taginst : taginst}(s, v_tagtype) = (s +++ {TAGS [v_taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|) - -- if (v_taginst = {TYPE v_tagtype}) - -- wf_store: `%`({TAGS [v_taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_taginst: `%`({TYPE v_tagtype}) + rule allocmem_is_wf_0{v_store : store, v_memtype : memtype, ret_val : (store, memaddr), var_0 : (store, memaddr)}: + `%%%`(v_store, v_memtype, ret_val) + -- wf_store: `%`(v_store) + -- wf_memtype: `%`(v_memtype) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocmem: `%%%`(v_store, v_memtype, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.1-20.102 -def $alloctags(v_store : store, var_0 : tagtype*) : (store, tagaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:21.1-21.34 - def $alloctags{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:22.1-24.49 - def $alloctags{s : store, v_tagtype : typeuse, tagtype'_lst : tagtype*}(s, [v_tagtype] ++ tagtype'_lst) = (s_2, [ja] ++ ja'_lst) - -- let{ja : tagaddr, s_1 : store} (s_1, ja) = $alloctag(s, v_tagtype) - -- let{s_2 : store, ja'_lst : tagaddr*} (s_2, ja'_lst) = $alloctags(s_1, tagtype'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_0{s : store}: + `%%%`(s, [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule fun_allocmems_case_1{s : store, v_memtype : memtype, memtype'_lst : memtype*, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [v_memtype] ++ memtype'_lst, (s_2, [ma] ++ ma'_lst)) + -- let{ma : memaddr, s_1 : store} (s_1, ma) = var_0 + -- let{s_2 : store, ma'_lst : memaddr*} (s_2, ma'_lst) = var_1 + -- fun_allocmems: `%%%`(s_1, memtype'_lst, var_1) + -- fun_allocmem: `%%%`(s, v_memtype, var_0) } -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(v_store : store, v_globaltype : globaltype, v_val : val) : (store, globaladdr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocglobal{s : store, v_globaltype : globaltype, v_val : val, v_globalinst : globalinst}(s, v_globaltype, v_val) = (s +++ {TAGS [], GLOBALS [v_globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|) - -- if (v_globalinst = {TYPE v_globaltype, VALUE v_val}) - -- wf_store: `%`({TAGS [], GLOBALS [v_globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_globalinst: `%`({TYPE v_globaltype, VALUE v_val}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:31.1-31.122 -def $allocglobals(v_store : store, var_0 : globaltype*, var_1 : val*) : (store, globaladdr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:32.1-32.42 - def $allocglobals{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:33.1-35.62 - def $allocglobals{s : store, v_globaltype : globaltype, globaltype'_lst : globaltype*, v_val : val, val'_lst : val*}(s, [v_globaltype] ++ globaltype'_lst, [v_val] ++ val'_lst) = (s_2, [ga] ++ ga'_lst) - -- let{ga : globaladdr, s_1 : store} (s_1, ga) = $allocglobal(s, v_globaltype, v_val) - -- let{s_2 : store, ga'_lst : globaladdr*} (s_2, ga'_lst) = $allocglobals(s_1, globaltype'_lst, val'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 +relation allocmems_is_wf: `%%%`(v_store : store, var_0 : memtype*, ret_val : (store, memaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 + rule allocmems_is_wf_0{v_store : store, var_0 : memtype*, ret_val : (store, memaddr*), var_1 : (store, memaddr*)}: + `%%%`(v_store, var_0, ret_val) + -- wf_store: `%`(v_store) + -- (wf_memtype: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocmems: `%%%`(v_store, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(v_store : store, v_memtype : memtype) : (store, memaddr) +relation fun_alloctable: `%%%%`(store, tabletype, ref, (store, tableaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_alloctable_case_0{s : store, at : addrtype, i : uN, j_opt : u64?, rt : reftype, v_ref : ref, v_tableinst : tableinst}: + `%%%%`(s, mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), v_ref, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [v_tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|)) + -- if (v_tableinst = {TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS v_ref^$proj_uN_0(i).0{}}) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(i, j_opt), rt), REFS v_ref^$proj_uN_0(i).0{}}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation alloctable_is_wf: `%%%%`(v_store : store, v_tabletype : tabletype, v_ref : ref, ret_val : (store, tableaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmem{s : store, at : addrtype, i : uN, j_opt : u64?, v_meminst : meminst}(s, `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt))) = (s +++ {TAGS [], GLOBALS [], MEMS [v_meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.MEMS_store|) - -- if (v_meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [v_meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + rule alloctable_is_wf_0{v_store : store, v_tabletype : tabletype, v_ref : ref, ret_val : (store, tableaddr), var_0 : (store, tableaddr)}: + `%%%%`(v_store, v_tabletype, v_ref, ret_val) + -- wf_store: `%`(v_store) + -- wf_tabletype: `%`(v_tabletype) + -- wf_ref: `%`(v_ref) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_alloctable: `%%%%`(v_store, v_tabletype, v_ref, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.1-42.102 -def $allocmems(v_store : store, var_0 : memtype*) : (store, memaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:43.1-43.34 - def $allocmems{s : store}(s, []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:44.1-46.49 - def $allocmems{s : store, v_memtype : memtype, memtype'_lst : memtype*}(s, [v_memtype] ++ memtype'_lst) = (s_2, [ma] ++ ma'_lst) - -- let{ma : memaddr, s_1 : store} (s_1, ma) = $allocmem(s, v_memtype) - -- let{s_2 : store, ma'_lst : memaddr*} (s_2, ma'_lst) = $allocmems(s_1, memtype'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation fun_alloctables: `%%%%`(store, tabletype*, ref*, (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule fun_alloctables_case_1{s : store, v_tabletype : tabletype, tabletype'_lst : tabletype*, v_ref : ref, ref'_lst : ref*, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: + `%%%%`(s, [v_tabletype] ++ tabletype'_lst, [v_ref] ++ ref'_lst, (s_2, [ta] ++ ta'_lst)) + -- let{ta : tableaddr, s_1 : store} (s_1, ta) = var_0 + -- let{s_2 : store, ta'_lst : tableaddr*} (s_2, ta'_lst) = var_1 + -- fun_alloctables: `%%%%`(s_1, tabletype'_lst, ref'_lst, var_1) + -- fun_alloctable: `%%%%`(s, v_tabletype, v_ref, var_0) } -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(v_store : store, v_tabletype : tabletype, v_ref : ref) : (store, tableaddr) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $alloctable{s : store, at : addrtype, i : uN, j_opt : u64?, rt : reftype, v_ref : ref, v_tableinst : tableinst}(s, `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), v_ref) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [v_tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TABLES_store|) - -- if (v_tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS v_ref^$proj_uN_0(i).0{}}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [v_tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS v_ref^$proj_uN_0(i).0{}}) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.1-53.118 -def $alloctables(v_store : store, var_0 : tabletype*, var_1 : ref*) : (store, tableaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:54.1-54.41 - def $alloctables{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:55.1-57.60 - def $alloctables{s : store, v_tabletype : tabletype, tabletype'_lst : tabletype*, v_ref : ref, ref'_lst : ref*}(s, [v_tabletype] ++ tabletype'_lst, [v_ref] ++ ref'_lst) = (s_2, [ta] ++ ta'_lst) - -- let{ta : tableaddr, s_1 : store} (s_1, ta) = $alloctable(s, v_tabletype, v_ref) - -- let{s_2 : store, ta'_lst : tableaddr*} (s_2, ta'_lst) = $alloctables(s_1, tabletype'_lst, ref'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 +relation alloctables_is_wf: `%%%%`(v_store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:53.6-53.18 + rule alloctables_is_wf_0{v_store : store, var_0 : tabletype*, var_1 : ref*, ret_val : (store, tableaddr*), var_2 : (store, tableaddr*)}: + `%%%%`(v_store, var_0, var_1, ret_val) + -- wf_store: `%`(v_store) + -- (wf_tabletype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_alloctables: `%%%%`(v_store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocfunc(v_store : store, v_deftype : deftype, v_funccode : funccode, v_moduleinst : moduleinst) : (store, funcaddr) +relation fun_allocfunc: `%%%%%`(store, deftype, funccode, moduleinst, (store, funcaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocfunc{s : store, v_deftype : deftype, v_funccode : funccode, v_moduleinst : moduleinst, v_funcinst : funcinst}(s, v_deftype, v_funccode, v_moduleinst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [v_funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|) + rule fun_allocfunc_case_0{s : store, v_deftype : deftype, v_funccode : funccode, v_moduleinst : moduleinst, v_funcinst : funcinst}: + `%%%%%`(s, v_deftype, v_funccode, v_moduleinst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [v_funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.FUNCS_store|)) -- if (v_funcinst = {TYPE v_deftype, MODULE v_moduleinst, CODE v_funccode}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [v_funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE v_deftype, MODULE v_moduleinst, CODE v_funccode}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocfunc_is_wf: `%%%%%`(v_store : store, v_deftype : deftype, v_funccode : funccode, v_moduleinst : moduleinst, ret_val : (store, funcaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocfunc_is_wf_0{v_store : store, v_deftype : deftype, v_funccode : funccode, v_moduleinst : moduleinst, ret_val : (store, funcaddr), var_0 : (store, funcaddr)}: + `%%%%%`(v_store, v_deftype, v_funccode, v_moduleinst, ret_val) + -- wf_store: `%`(v_store) + -- wf_funccode: `%`(v_funccode) + -- wf_moduleinst: `%`(v_moduleinst) + -- if (ret_val = var_0) + -- wf_store: `%`(ret_val.0) + -- fun_allocfunc: `%%%%%`(v_store, v_deftype, v_funccode, v_moduleinst, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_0{s : store}: + `%%%%%`(s, [], [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule fun_allocfuncs_case_1{s : store, dt : deftype, dt'_lst : deftype*, v_funccode : funccode, funccode'_lst : funccode*, v_moduleinst : moduleinst, moduleinst'_lst : moduleinst*, var_1 : (store, funcaddr*), var_0 : (store, funcaddr)}: + `%%%%%`(s, [dt] ++ dt'_lst, [v_funccode] ++ funccode'_lst, [v_moduleinst] ++ moduleinst'_lst, (s_2, [fa] ++ fa'_lst)) + -- let{fa : funcaddr, s_1 : store} (s_1, fa) = var_0 + -- let{s_2 : store, fa'_lst : funcaddr*} (s_2, fa'_lst) = var_1 + -- fun_allocfuncs: `%%%%%`(s_1, dt'_lst, funccode'_lst, moduleinst'_lst, var_1) + -- fun_allocfunc: `%%%%%`(s, dt, v_funccode, v_moduleinst, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.1-64.133 -def $allocfuncs(v_store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*) : (store, funcaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:65.1-65.45 - def $allocfuncs{s : store}(s, [], [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:66.1-68.71 - def $allocfuncs{s : store, dt : deftype, dt'_lst : deftype*, v_funccode : funccode, funccode'_lst : funccode*, v_moduleinst : moduleinst, moduleinst'_lst : moduleinst*}(s, [dt] ++ dt'_lst, [v_funccode] ++ funccode'_lst, [v_moduleinst] ++ moduleinst'_lst) = (s_2, [fa] ++ fa'_lst) - -- let{fa : funcaddr, s_1 : store} (s_1, fa) = $allocfunc(s, dt, v_funccode, v_moduleinst) - -- let{s_2 : store, fa'_lst : funcaddr*} (s_2, fa'_lst) = $allocfuncs(s_1, dt'_lst, funccode'_lst, moduleinst'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 +relation allocfuncs_is_wf: `%%%%%`(v_store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:64.6-64.17 + rule allocfuncs_is_wf_0{v_store : store, var_0 : deftype*, var_1 : funccode*, var_2 : moduleinst*, ret_val : (store, funcaddr*), var_3 : (store, funcaddr*)}: + `%%%%%`(v_store, var_0, var_1, var_2, ret_val) + -- wf_store: `%`(v_store) + -- (wf_funccode: `%`(var_1))*{var_1 <- var_1} + -- (wf_moduleinst: `%`(var_2))*{var_2 <- var_2} + -- if (ret_val = var_3) + -- wf_store: `%`(ret_val.0) + -- fun_allocfuncs: `%%%%%`(v_store, var_0, var_1, var_2, var_3) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocdata(v_store : store, v_datatype : datatype, var_0 : byte*) : (store, dataaddr) +relation fun_allocdata: `%%%%`(store, datatype, byte*, (store, dataaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocdata{s : store, byte_lst : byte*, v_datainst : datainst}(s, OK_datatype, byte_lst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [v_datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|) + rule fun_allocdata_case_0{s : store, byte_lst : byte*, v_datainst : datainst}: + `%%%%`(s, OK_datatype, byte_lst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [v_datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.DATAS_store|)) -- if (v_datainst = {BYTES byte_lst}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [v_datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte_lst}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocdata_is_wf: `%%%%`(v_store : store, v_datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocdata_is_wf_0{v_store : store, v_datatype : datatype, var_0 : byte*, ret_val : (store, dataaddr), var_1 : (store, dataaddr)}: + `%%%%`(v_store, v_datatype, var_0, ret_val) + -- wf_store: `%`(v_store) + -- (wf_byte: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocdata: `%%%%`(v_store, v_datatype, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation fun_allocdatas: `%%%%`(store, datatype*, byte**, (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule fun_allocdatas_case_1{s : store, ok : datatype, ok'_lst : datatype*, b_lst : byte*, b'_lst_lst : byte**, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(s, [ok] ++ ok'_lst, [b_lst] ++ b'_lst_lst, (s_2, [da] ++ da'_lst)) + -- let{da : dataaddr, s_1 : store} (s_1, da) = var_0 + -- let{s_2 : store, da'_lst : dataaddr*} (s_2, da'_lst) = var_1 + -- fun_allocdatas: `%%%%`(s_1, ok'_lst, b'_lst_lst, var_1) + -- fun_allocdata: `%%%%`(s, ok, b_lst, var_0) +} + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.1-75.118 -def $allocdatas(v_store : store, var_0 : datatype*, var_1 : byte**) : (store, dataaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:76.1-76.40 - def $allocdatas{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:77.1-79.53 - def $allocdatas{s : store, ok : datatype, ok'_lst : datatype*, b_lst : byte*, b'_lst_lst : byte**}(s, [ok] ++ ok'_lst, [b_lst] ++ b'_lst_lst) = (s_2, [da] ++ da'_lst) - -- let{da : dataaddr, s_1 : store} (s_1, da) = $allocdata(s, ok, b_lst) - -- let{s_2 : store, da'_lst : dataaddr*} (s_2, da'_lst) = $allocdatas(s_1, ok'_lst, b'_lst_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 +relation allocdatas_is_wf: `%%%%`(v_store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:75.6-75.17 + rule allocdatas_is_wf_0{v_store : store, var_0 : datatype*, var_1 : byte**, ret_val : (store, dataaddr*), var_2 : (store, dataaddr*)}: + `%%%%`(v_store, var_0, var_1, ret_val) + -- wf_store: `%`(v_store) + -- (wf_byte: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocdatas: `%%%%`(v_store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocelem(v_store : store, v_elemtype : elemtype, var_0 : ref*) : (store, elemaddr) +relation fun_allocelem: `%%%%`(store, elemtype, ref*, (store, elemaddr)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocelem{s : store, v_elemtype : reftype, ref_lst : ref*, v_eleminst : eleminst}(s, v_elemtype, ref_lst) = (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [v_eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|) + rule fun_allocelem_case_0{s : store, v_elemtype : reftype, ref_lst : ref*, v_eleminst : eleminst}: + `%%%%`(s, v_elemtype, ref_lst, (s +++ {TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [v_eleminst], STRUCTS [], ARRAYS [], EXNS []}, |s.ELEMS_store|)) -- if (v_eleminst = {TYPE v_elemtype, REFS ref_lst}) - -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [v_eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE v_elemtype, REFS ref_lst}) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocelem_is_wf: `%%%%`(v_store : store, v_elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocelem_is_wf_0{v_store : store, v_elemtype : elemtype, var_0 : ref*, ret_val : (store, elemaddr), var_1 : (store, elemaddr)}: + `%%%%`(v_store, v_elemtype, var_0, ret_val) + -- wf_store: `%`(v_store) + -- wf_reftype: `%`(v_elemtype) + -- (wf_ref: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_store: `%`(ret_val.0) + -- fun_allocelem: `%%%%`(v_store, v_elemtype, var_0, var_1) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.1-86.117 -def $allocelems(v_store : store, var_0 : elemtype*, var_1 : ref**) : (store, elemaddr*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:87.1-87.40 - def $allocelems{s : store}(s, [], []) = (s, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:88.1-90.55 - def $allocelems{s : store, rt : reftype, rt'_lst : reftype*, ref_lst : ref*, ref'_lst_lst : ref**}(s, [rt] ++ rt'_lst, [ref_lst] ++ ref'_lst_lst) = (s_2, [ea] ++ ea'_lst) - -- let{ea : elemaddr, s_1 : store} (s_1, ea) = $allocelem(s, rt, ref_lst) - -- let{s_2 : store, ea'_lst : elemaddr*} (s_2, ea'_lst) = $allocelems(s_1, rt'_lst, ref'_lst_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation fun_allocelems: `%%%%`(store, elemtype*, ref**, (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_0{s : store}: + `%%%%`(s, [], [], (s, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule fun_allocelems_case_1{s : store, rt : reftype, rt'_lst : reftype*, ref_lst : ref*, ref'_lst_lst : ref**, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: + `%%%%`(s, [rt] ++ rt'_lst, [ref_lst] ++ ref'_lst_lst, (s_2, [ea] ++ ea'_lst)) + -- let{ea : elemaddr, s_1 : store} (s_1, ea) = var_0 + -- let{s_2 : store, ea'_lst : elemaddr*} (s_2, ea'_lst) = var_1 + -- fun_allocelems: `%%%%`(s_1, rt'_lst, ref'_lst_lst, var_1) + -- fun_allocelem: `%%%%`(s, rt, ref_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 +relation allocelems_is_wf: `%%%%`(v_store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:86.6-86.17 + rule allocelems_is_wf_0{v_store : store, var_0 : elemtype*, var_1 : ref**, ret_val : (store, elemaddr*), var_2 : (store, elemaddr*)}: + `%%%%`(v_store, var_0, var_1, ret_val) + -- wf_store: `%`(v_store) + -- (wf_reftype: `%`(var_0))*{var_0 <- var_0} + -- (wf_ref: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_store: `%`(ret_val.0) + -- fun_allocelems: `%%%%`(v_store, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport(v_moduleinst : moduleinst, v_export : export) : exportinst ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{v_moduleinst : moduleinst, v_name : name, x : uN}(v_moduleinst, EXPORT_export(v_name, TAG_externidx(x))) = {NAME v_name, ADDR TAG_externaddr(v_moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME v_name, ADDR TAG_externaddr(v_moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{v_moduleinst : moduleinst, v_name : name, x : uN}(v_moduleinst, EXPORT_export(v_name, GLOBAL_externidx(x))) = {NAME v_name, ADDR GLOBAL_externaddr(v_moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME v_name, ADDR GLOBAL_externaddr(v_moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{v_moduleinst : moduleinst, v_name : name, x : uN}(v_moduleinst, EXPORT_export(v_name, MEM_externidx(x))) = {NAME v_name, ADDR MEM_externaddr(v_moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME v_name, ADDR MEM_externaddr(v_moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{v_moduleinst : moduleinst, v_name : name, x : uN}(v_moduleinst, EXPORT_export(v_name, TABLE_externidx(x))) = {NAME v_name, ADDR TABLE_externaddr(v_moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME v_name, ADDR TABLE_externaddr(v_moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexport{v_moduleinst : moduleinst, v_name : name, x : uN}(v_moduleinst, EXPORT_export(v_name, FUNC_externidx(x))) = {NAME v_name, ADDR FUNC_externaddr(v_moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])} - -- wf_exportinst: `%`({NAME v_name, ADDR FUNC_externaddr(v_moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocexport_is_wf: `%%%`(v_moduleinst : moduleinst, v_export : export, ret_val : exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexport_is_wf_0{v_moduleinst : moduleinst, v_export : export, ret_val : exportinst}: + `%%%`(v_moduleinst, v_export, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- wf_export: `%`(v_export) + -- if (ret_val = $allocexport(v_moduleinst, v_export)) + -- wf_exportinst: `%`(ret_val) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec def $allocexports(v_moduleinst : moduleinst, var_0 : export*) : exportinst* @@ -15059,164 +19619,350 @@ def $allocexports(v_moduleinst : moduleinst, var_0 : export*) : exportinst* def $allocexports{v_moduleinst : moduleinst, export_lst : export*}(v_moduleinst, export_lst) = $allocexport(v_moduleinst, v_export)*{v_export <- export_lst} ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmodule(v_store : store, v_module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**) : (store, moduleinst) +relation allocexports_is_wf: `%%%`(v_moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocexports_is_wf_0{v_moduleinst : moduleinst, var_0 : export*, ret_val : exportinst*}: + `%%%`(v_moduleinst, var_0, ret_val) + -- wf_moduleinst: `%`(v_moduleinst) + -- (wf_export: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = $allocexports(v_moduleinst, var_0)) + -- (wf_exportinst: `%`(ret_val))*{ret_val <- ret_val} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref**, (store, moduleinst)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocmodule{s : store, v_module : module, externaddr_lst : externaddr*, val_G_lst : val*, ref_T_lst : ref*, ref_E_lst_lst : ref**, s_7 : store, v_moduleinst : moduleinst, tagtype_lst : tagtype*, expr_G_lst : expr*, globaltype_lst : globaltype*, memtype_lst : memtype*, expr_T_lst : expr*, tabletype_lst : tabletype*, expr_F_lst : expr*, local_lst_lst : local**, x_lst : idx*, byte_lst_lst : byte**, datamode_lst : datamode*, elemmode_lst : elemmode*, elemtype_lst : elemtype*, expr_E_lst_lst : expr**, xi_lst : exportinst*}(s, v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst) = (s_7, v_moduleinst) - -- let{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*} MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst)) = v_module - -- if (tag_lst = TAG_tag(tagtype#78)*{tagtype#78 <- tagtype_lst}) - -- if (global_lst = GLOBAL_global(globaltype#122, expr_G#1)*{expr_G#1 <- expr_G_lst, globaltype#122 <- globaltype_lst}) - -- if (mem_lst = MEMORY_mem(memtype#122)*{memtype#122 <- memtype_lst}) - -- if (table_lst = TABLE_table(tabletype#156, expr_T#1)*{expr_T#1 <- expr_T_lst, tabletype#156 <- tabletype_lst}) - -- if (func_lst = FUNC_func(x#2, local_lst#82, expr_F#1)*{expr_F#1 <- expr_F_lst, local_lst#82 <- local_lst_lst, x#2 <- x_lst}) - -- if (data_lst = DATA_data(byte_lst#110, datamode#110)*{byte_lst#110 <- byte_lst_lst, datamode#110 <- datamode_lst}) - -- if (elem_lst = ELEM_elem(elemtype#1, expr_E_lst#1, elemmode#230)*{elemmode#230 <- elemmode_lst, elemtype#1 <- elemtype_lst, expr_E_lst#1 <- expr_E_lst_lst}) - -- let{aa_I_lst : tagaddr*} aa_I_lst = $tagsxa(externaddr_lst) - -- let{ga_I_lst : globaladdr*} ga_I_lst = $globalsxa(externaddr_lst) - -- let{ma_I_lst : memaddr*} ma_I_lst = $memsxa(externaddr_lst) - -- let{ta_I_lst : tableaddr*} ta_I_lst = $tablesxa(externaddr_lst) - -- let{fa_I_lst : funcaddr*} fa_I_lst = $funcsxa(externaddr_lst) - -- let{dt_lst : deftype*} dt_lst = $alloctypes(type_lst) - -- let{fa_lst : nat*} fa_lst = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func_lst|){} - -- let{s_1 : store, aa_lst : tagaddr*} (s_1, aa_lst) = $alloctags(s, $subst_all_tagtype(tagtype#80, $typeuse_deftype(dt#9)*{dt#9 <- dt_lst})*{tagtype#80 <- tagtype_lst}) - -- let{s_2 : store, ga_lst : globaladdr*} (s_2, ga_lst) = $allocglobals(s_1, $subst_all_globaltype(globaltype#124, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst})*{globaltype#124 <- globaltype_lst}, val_G_lst) - -- let{s_3 : store, ma_lst : memaddr*} (s_3, ma_lst) = $allocmems(s_2, $subst_all_memtype(memtype#124, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst})*{memtype#124 <- memtype_lst}) - -- let{s_4 : store, ta_lst : tableaddr*} (s_4, ta_lst) = $alloctables(s_3, $subst_all_tabletype(tabletype#158, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst})*{tabletype#158 <- tabletype_lst}, ref_T_lst) - -- let{s_5 : store, da_lst : dataaddr*} (s_5, da_lst) = $allocdatas(s_4, OK_datatype^|data_lst|{}, byte_lst_lst) - -- let{s_6 : store, ea_lst : elemaddr*} (s_6, ea_lst) = $allocelems(s_5, $subst_all_reftype(elemtype#2, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst})*{elemtype#2 <- elemtype_lst}, ref_E_lst_lst) - -- if ((s_7, fa_lst) = $allocfuncs(s_6, dt_lst[$proj_uN_0(x#3).0]*{x#3 <- x_lst}, FUNC_funccode(x#4, local_lst#84, expr_F#2)*{expr_F#2 <- expr_F_lst, local_lst#84 <- local_lst_lst, x#4 <- x_lst}, v_moduleinst^|func_lst|{})) + rule fun_allocmodule_case_0{s : store, v_module : module, externaddr_lst : externaddr*, val_G_lst : val*, ref_T_lst : ref*, ref_E_lst_lst : ref**, s_7 : store, v_moduleinst : moduleinst, tagtype_lst : tagtype*, expr_G_lst : expr*, globaltype_lst : globaltype*, memtype_lst : memtype*, expr_T_lst : expr*, tabletype_lst : tabletype*, expr_F_lst : expr*, local_lst_lst : local**, x_lst : idx*, byte_lst_lst : byte**, datamode_lst : datamode*, elemmode_lst : elemmode*, elemtype_lst : elemtype*, expr_E_lst_lst : expr**, xi_lst : exportinst*, var_17 : (store, funcaddr*), var_16_lst : elemtype*, var_15 : (store, elemaddr*), var_14 : (store, dataaddr*), var_13_lst : tabletype*, var_12 : (store, tableaddr*), var_11_lst : memtype*, var_10 : (store, memaddr*), var_9_lst : globaltype*, var_8 : (store, globaladdr*), var_7_lst : tagtype*, var_6 : (store, tagaddr*), var_5 : deftype*, var_4 : funcaddr*, var_3 : tableaddr*, var_2 : memaddr*, var_1 : globaladdr*, var_0 : tagaddr*}: + `%%%%%%%`(s, v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, (s_7, v_moduleinst)) + -- let{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*} MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)) = v_module + -- if (tag_lst = TAG_tag(tagtype_78)*{tagtype_78 <- tagtype_lst}) + -- if (global_lst = GLOBAL_global(globaltype_122, expr_G_1)*{expr_G_1 <- expr_G_lst, globaltype_122 <- globaltype_lst}) + -- if (mem_lst = MEMORY_mem(memtype_122)*{memtype_122 <- memtype_lst}) + -- if (table_lst = TABLE_table(tabletype_156, expr_T_1)*{expr_T_1 <- expr_T_lst, tabletype_156 <- tabletype_lst}) + -- if (func_lst = FUNC_func(x_2, local_lst_82, expr_F_1)*{expr_F_1 <- expr_F_lst, local_lst_82 <- local_lst_lst, x_2 <- x_lst}) + -- if (data_lst = DATA_data(byte_lst_110, datamode_110)*{byte_lst_110 <- byte_lst_lst, datamode_110 <- datamode_lst}) + -- if (elem_lst = ELEM_elem(elemtype_1, expr_E_lst_1, elemmode_230)*{elemmode_230 <- elemmode_lst, elemtype_1 <- elemtype_lst, expr_E_lst_1 <- expr_E_lst_lst}) + -- let{aa_I_lst : tagaddr*} aa_I_lst = var_0 + -- let{ga_I_lst : globaladdr*} ga_I_lst = var_1 + -- let{ma_I_lst : memaddr*} ma_I_lst = var_2 + -- let{ta_I_lst : tableaddr*} ta_I_lst = var_3 + -- let{fa_I_lst : funcaddr*} fa_I_lst = var_4 + -- let{dt_lst : deftype*} dt_lst = var_5 + -- let{fa_lst : nat*} fa_lst = (|s.FUNCS_store| + i_F_1)^(i_F_1<|func_lst|){} + -- let{s_1 : store, aa_lst : tagaddr*} (s_1, aa_lst) = var_6 + -- let{s_2 : store, ga_lst : globaladdr*} (s_2, ga_lst) = var_8 + -- let{s_3 : store, ma_lst : memaddr*} (s_3, ma_lst) = var_10 + -- let{s_4 : store, ta_lst : tableaddr*} (s_4, ta_lst) = var_12 + -- let{s_5 : store, da_lst : dataaddr*} (s_5, da_lst) = var_14 + -- let{s_6 : store, ea_lst : elemaddr*} (s_6, ea_lst) = var_15 + -- if ((s_7, fa_lst) = var_17) -- if (xi_lst = $allocexports({TYPES [], TAGS aa_I_lst ++ aa_lst, GLOBALS ga_I_lst ++ ga_lst, MEMS ma_I_lst ++ ma_lst, TABLES ta_I_lst ++ ta_lst, FUNCS fa_I_lst ++ fa_lst, DATAS [], ELEMS [], EXPORTS []}, export_lst)) -- if (v_moduleinst = {TYPES dt_lst, TAGS aa_I_lst ++ aa_lst, GLOBALS ga_I_lst ++ ga_lst, MEMS ma_I_lst ++ ma_lst, TABLES ta_I_lst ++ ta_lst, FUNCS fa_I_lst ++ fa_lst, DATAS da_lst, ELEMS ea_lst, EXPORTS xi_lst}) - -- wf_store: `%`(s_7) - -- wf_moduleinst: `%`(v_moduleinst) - -- wf_module: `%`(MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) - -- (wf_tag: `%`(TAG_tag(tagtype#81)))*{tagtype#81 <- tagtype_lst} - -- (wf_global: `%`(GLOBAL_global(globaltype#125, expr_G#2)))*{expr_G#2 <- expr_G_lst, globaltype#125 <- globaltype_lst} - -- (wf_mem: `%`(MEMORY_mem(memtype#125)))*{memtype#125 <- memtype_lst} - -- (wf_table: `%`(TABLE_table(tabletype#159, expr_T#2)))*{expr_T#2 <- expr_T_lst, tabletype#159 <- tabletype_lst} - -- (wf_func: `%`(FUNC_func(x#5, local_lst#85, expr_F#3)))*{expr_F#3 <- expr_F_lst, local_lst#85 <- local_lst_lst, x#5 <- x_lst} - -- (wf_data: `%`(DATA_data(byte_lst#113, datamode#112)))*{byte_lst#113 <- byte_lst_lst, datamode#112 <- datamode_lst} - -- (wf_elem: `%`(ELEM_elem(elemtype#3, expr_E_lst#2, elemmode#232)))*{elemmode#232 <- elemmode_lst, elemtype#3 <- elemtype_lst, expr_E_lst#2 <- expr_E_lst_lst} + -- wf_module: `%`(MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst))) + -- (wf_tag: `%`(TAG_tag(tagtype_81)))*{tagtype_81 <- tagtype_lst} + -- (wf_global: `%`(GLOBAL_global(globaltype_125, expr_G_2)))*{expr_G_2 <- expr_G_lst, globaltype_125 <- globaltype_lst} + -- if (|expr_G_lst| = |globaltype_lst|) + -- (wf_mem: `%`(MEMORY_mem(memtype_125)))*{memtype_125 <- memtype_lst} + -- (wf_table: `%`(TABLE_table(tabletype_159, expr_T_2)))*{expr_T_2 <- expr_T_lst, tabletype_159 <- tabletype_lst} + -- if (|expr_T_lst| = |tabletype_lst|) + -- (wf_func: `%`(FUNC_func(x_5, local_lst_85, expr_F_3)))*{expr_F_3 <- expr_F_lst, local_lst_85 <- local_lst_lst, x_5 <- x_lst} + -- if (|expr_F_lst| = |local_lst_lst|) + -- if (|expr_F_lst| = |x_lst|) + -- (wf_data: `%`(DATA_data(byte_lst_113, datamode_112)))*{byte_lst_113 <- byte_lst_lst, datamode_112 <- datamode_lst} + -- if (|byte_lst_lst| = |datamode_lst|) + -- (wf_elem: `%`(ELEM_elem(elemtype_3, expr_E_lst_2, elemmode_232)))*{elemmode_232 <- elemmode_lst, elemtype_3 <- elemtype_lst, expr_E_lst_2 <- expr_E_lst_lst} + -- if (|elemmode_lst| = |elemtype_lst|) + -- if (|elemmode_lst| = |expr_E_lst_lst|) -- wf_moduleinst: `%`({TYPES [], TAGS aa_I_lst ++ aa_lst, GLOBALS ga_I_lst ++ ga_lst, MEMS ma_I_lst ++ ma_lst, TABLES ta_I_lst ++ ta_lst, FUNCS fa_I_lst ++ fa_lst, DATAS [], ELEMS [], EXPORTS []}) -- wf_moduleinst: `%`({TYPES dt_lst, TAGS aa_I_lst ++ aa_lst, GLOBALS ga_I_lst ++ ga_lst, MEMS ma_I_lst ++ ma_lst, TABLES ta_I_lst ++ ta_lst, FUNCS fa_I_lst ++ fa_lst, DATAS da_lst, ELEMS ea_lst, EXPORTS xi_lst}) + -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x_3).0]*{x_3 <- x_lst}, FUNC_funccode(x_4, local_lst_84, expr_F_2)*{expr_F_2 <- expr_F_lst, local_lst_84 <- local_lst_lst, x_4 <- x_lst}, v_moduleinst^|func_lst|{}, var_17) + -- (if ($proj_uN_0(x_3).0 < |dt_lst|))*{x_3 <- x_lst} + -- (fun_subst_all_reftype: `%%%`(elemtype_2, $typeuse_deftype(dt_13)*{dt_13 <- dt_lst}, var_16))*{var_16 <- var_16_lst, elemtype_2 <- elemtype_lst} + -- if (|var_16_lst| = |elemtype_lst|) + -- fun_allocelems: `%%%%`(s_5, var_16_lst, ref_E_lst_lst, var_15) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data_lst|{}, byte_lst_lst, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype_158, $typeuse_deftype(dt_12)*{dt_12 <- dt_lst}, var_13))*{var_13 <- var_13_lst, tabletype_158 <- tabletype_lst} + -- if (|var_13_lst| = |tabletype_lst|) + -- fun_alloctables: `%%%%`(s_3, var_13_lst, ref_T_lst, var_12) + -- (fun_subst_all_memtype: `%%%`(memtype_124, $typeuse_deftype(dt_11)*{dt_11 <- dt_lst}, var_11))*{var_11 <- var_11_lst, memtype_124 <- memtype_lst} + -- if (|var_11_lst| = |memtype_lst|) + -- fun_allocmems: `%%%`(s_2, var_11_lst, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype_124, $typeuse_deftype(dt_10)*{dt_10 <- dt_lst}, var_9))*{var_9 <- var_9_lst, globaltype_124 <- globaltype_lst} + -- if (|var_9_lst| = |globaltype_lst|) + -- fun_allocglobals: `%%%%`(s_1, var_9_lst, val_G_lst, var_8) + -- (fun_subst_all_tagtype: `%%%`(tagtype_80, $typeuse_deftype(dt_9)*{dt_9 <- dt_lst}, var_7))*{var_7 <- var_7_lst, tagtype_80 <- tagtype_lst} + -- if (|var_7_lst| = |tagtype_lst|) + -- fun_alloctags: `%%%`(s, var_7_lst, var_6) + -- fun_alloctypes: `%%`(type_lst, var_5) + -- fun_funcsxa: `%%`(externaddr_lst, var_4) + -- fun_tablesxa: `%%`(externaddr_lst, var_3) + -- fun_memsxa: `%%`(externaddr_lst, var_2) + -- fun_globalsxa: `%%`(externaddr_lst, var_1) + -- fun_tagsxa: `%%`(externaddr_lst, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation allocmodule_is_wf: `%%%%%%%`(v_store : store, v_module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule allocmodule_is_wf_0{v_store : store, v_module : module, var_0 : externaddr*, var_1 : val*, var_2 : ref*, var_3 : ref**, ret_val : (store, moduleinst), var_4 : (store, moduleinst)}: + `%%%%%%%`(v_store, v_module, var_0, var_1, var_2, var_3, ret_val) + -- wf_store: `%`(v_store) + -- wf_module: `%`(v_module) + -- (wf_val: `%`(var_1))*{var_1 <- var_1} + -- (wf_ref: `%`(var_2))*{var_2 <- var_2} + -- (wf_ref: `%`(var_3))*{var_3 <- var_3}*{var_3 <- var_3} + -- if (ret_val = var_4) + -- wf_store: `%`(ret_val.0) + -- wf_moduleinst: `%`(ret_val.1) + -- fun_allocmodule: `%%%%%%%`(v_store, v_module, var_0, var_1, var_2, var_3, var_4) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $rundata_(v_dataidx : dataidx, v_data : data) : instr* +relation fun_rundata_: `%%%`(dataidx, data, instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, v_n : nat, b_lst : byte*}(x, DATA_data(b_lst, PASSIVE_datamode)) = [] + rule fun_rundata__case_0{x : uN, v_n : nat, b_lst : byte*}: + `%%%`(x, DATA_data(b_lst, PASSIVE_datamode), []) + -- if (v_n = |b_lst|) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_rundata__case_1{x : uN, v_n : nat, b_lst : byte*, y : uN, instr_lst : instr*}: + `%%%`(x, DATA_data(b_lst, ACTIVE_datamode(y, instr_lst)), instr_lst ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) MEMORY_INIT_instr(y, x) DATA_DROP_instr(x)]) + -- if (v_n = |b_lst|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation rundata__is_wf: `%%%`(v_dataidx : dataidx, v_data : data, ret_val : instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $rundata_{x : uN, v_n : nat, b_lst : byte*, y : uN, instr_lst : instr*}(x, DATA_data(b_lst, ACTIVE_datamode(y, instr_lst))) = instr_lst ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `MEMORY.INIT`_instr(y, x) `DATA.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n)))) - -- wf_instr: `%`(`MEMORY.INIT`_instr(y, x)) - -- wf_instr: `%`(`DATA.DROP`_instr(x)) + rule rundata__is_wf_0{v_dataidx : dataidx, v_data : data, ret_val : instr*, var_0 : instr*}: + `%%%`(v_dataidx, v_data, ret_val) + -- wf_uN: `%%`(32, v_dataidx) + -- wf_data: `%`(v_data) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_rundata_: `%%%`(v_dataidx, v_data, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $runelem_(v_elemidx : elemidx, v_elem : elem) : instr* +relation fun_runelem_: `%%%`(elemidx, elem, instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_runelem__case_0{x : uN, rt : reftype, v_n : nat, e_lst : expr*}: + `%%%`(x, ELEM_elem(rt, e_lst, PASSIVE_elemmode), []) + -- if (v_n = |e_lst|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, v_n : nat, e_lst : expr*}(x, ELEM_elem(rt, e_lst, PASSIVE_elemmode)) = [] + rule fun_runelem__case_1{x : uN, rt : reftype, v_n : nat, e_lst : expr*}: + `%%%`(x, ELEM_elem(rt, e_lst, DECLARE_elemmode), [ELEM_DROP_instr(x)]) + -- if (v_n = |e_lst|) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, v_n : nat, e_lst : expr*}(x, ELEM_elem(rt, e_lst, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule fun_runelem__case_2{x : uN, rt : reftype, v_n : nat, e_lst : expr*, y : uN, instr_lst : instr*}: + `%%%`(x, ELEM_elem(rt, e_lst, ACTIVE_elemmode(y, instr_lst)), instr_lst ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, mk_uN_uN(v_n))) TABLE_INIT_instr(y, x) ELEM_DROP_instr(x)]) + -- if (v_n = |e_lst|) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation runelem__is_wf: `%%%`(v_elemidx : elemidx, v_elem : elem, ret_val : instr*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $runelem_{x : uN, rt : reftype, v_n : nat, e_lst : expr*, y : uN, instr_lst : instr*}(x, ELEM_elem(rt, e_lst, ACTIVE_elemmode(y, instr_lst))) = instr_lst ++ [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0))) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n))) `TABLE.INIT`_instr(y, x) `ELEM.DROP`_instr(x)] - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) - -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(v_n)))) - -- wf_instr: `%`(`TABLE.INIT`_instr(y, x)) - -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + rule runelem__is_wf_0{v_elemidx : elemidx, v_elem : elem, ret_val : instr*, var_0 : instr*}: + `%%%`(v_elemidx, v_elem, ret_val) + -- wf_uN: `%%`(32, v_elemidx) + -- wf_elem: `%`(v_elem) + -- if (ret_val = var_0) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + -- fun_runelem_: `%%%`(v_elemidx, v_elem, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.1-160.92 -def $evalexprs(v_state : state, var_0 : expr*) : (state, ref*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:161.1-161.34 - def $evalexprs{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:162.1-165.46 - def $evalexprs{z : state, v_expr : instr*, expr'_lst : expr*, v_ref : ref, z' : state}(z, [v_expr] ++ expr'_lst) = (z'', [v_ref] ++ ref'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule fun_evalexprs_case_1{z : state, v_expr : instr*, expr'_lst : expr*, v_ref : ref, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [v_expr] ++ expr'_lst, (z'', [v_ref] ++ ref'_lst)) -- Eval_expr: `%;%~>*%;%`(z, v_expr, z', [$val_ref(v_ref)]) - -- let{z'' : state, ref'_lst : ref*} (z'', ref'_lst) = $evalexprs(z', expr'_lst) - -- wf_ref: `%`(v_ref) + -- let{z'' : state, ref'_lst : ref*} (z'', ref'_lst) = var_0 -- wf_state: `%`(z') + -- fun_evalexprs: `%%%`(z', expr'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 +relation evalexprs_is_wf: `%%%`(v_state : state, var_0 : expr*, ret_val : (state, ref*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 + rule evalexprs_is_wf_0{v_state : state, var_0 : expr*, ret_val : (state, ref*), var_1 : (state, ref*)}: + `%%%`(v_state, var_0, ret_val) + -- wf_state: `%`(v_state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- ret_val.1} + -- fun_evalexprs: `%%%`(v_state, var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_0{z : state}: + `%%%`(z, [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule fun_evalexprss_case_1{z : state, expr_lst : expr*, expr'_lst_lst : expr**, var_1 : (state, ref**), var_0 : (state, ref*)}: + `%%%`(z, [expr_lst] ++ expr'_lst_lst, (z'', [ref_lst] ++ ref'_lst_lst)) + -- let{ref_lst : ref*, z' : state} (z', ref_lst) = var_0 + -- let{z'' : state, ref'_lst_lst : ref**} (z'', ref'_lst_lst) = var_1 + -- fun_evalexprss: `%%%`(z', expr'_lst_lst, var_1) + -- fun_evalexprs: `%%%`(z, expr_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.1-167.96 -def $evalexprss(v_state : state, var_0 : expr**) : (state, ref**) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:168.1-168.35 - def $evalexprss{z : state}(z, []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:169.1-172.49 - def $evalexprss{z : state, expr_lst : expr*, expr'_lst_lst : expr**}(z, [expr_lst] ++ expr'_lst_lst) = (z'', [ref_lst] ++ ref'_lst_lst) - -- let{ref_lst : ref*, z' : state} (z', ref_lst) = $evalexprs(z, expr_lst) - -- let{z'' : state, ref'_lst_lst : ref**} (z'', ref'_lst_lst) = $evalexprss(z', expr'_lst_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 +relation evalexprss_is_wf: `%%%`(v_state : state, var_0 : expr**, ret_val : (state, ref**)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 + rule evalexprss_is_wf_0{v_state : state, var_0 : expr**, ret_val : (state, ref**), var_1 : (state, ref**)}: + `%%%`(v_state, var_0, ret_val) + -- wf_state: `%`(v_state) + -- (wf_instr: `%`(var_0))*{var_0 <- var_0}*{var_0 <- var_0}*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_state: `%`(ret_val.0) + -- (wf_ref: `%`(iter))*{iter <- iter}*{iter <- ret_val.1} + -- fun_evalexprss: `%%%`(v_state, var_0, var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rec { -;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.1-174.111 -def $evalglobals(v_state : state, var_0 : globaltype*, var_1 : expr*) : (state, val*) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:175.1-175.41 - def $evalglobals{z : state}(z, [], []) = (z, []) - ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:176.1-181.82 - def $evalglobals{z : state, gt : globaltype, gt'_lst : globaltype*, v_expr : instr*, expr'_lst : expr*, v_val : val, z' : state}(z, [gt] ++ gt'_lst, [v_expr] ++ expr'_lst) = (z'', [v_val] ++ val'_lst) +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_0{z : state}: + `%%%%`(z, [], [], (z, [])) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule fun_evalglobals_case_1{z : state, gt : globaltype, gt'_lst : globaltype*, v_expr : instr*, expr'_lst : expr*, v_val : val, z' : state, var_1 : (state, val*), var_0 : (store, globaladdr)}: + `%%%%`(z, [gt] ++ gt'_lst, [v_expr] ++ expr'_lst, (z'', [v_val] ++ val'_lst)) -- Eval_expr: `%;%~>*%;%`(z, v_expr, z', [v_val]) - -- let{s : store, f : frame} `%;%`_state(s, f) = z' - -- let{s' : store, a : addr} (s', a) = $allocglobal(s, gt, v_val) - -- let{z'' : state, val'_lst : val*} (z'', val'_lst) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'_lst, expr'_lst) - -- wf_val: `%`(v_val) + -- let{s : store, f : frame} mk_state_state(s, f) = z' + -- let{s' : store, a : addr} (s', a) = var_0 + -- let{z'' : state, val'_lst : val*} (z'', val'_lst) = var_1 -- wf_state: `%`(z') - -- wf_state: `%`(`%;%`_state(s, f)) - -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- wf_state: `%`(mk_state_state(s, f)) + -- wf_state: `%`(mk_state_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- fun_evalglobals: `%%%%`(mk_state_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'_lst, expr'_lst, var_1) + -- fun_allocglobal: `%%%%`(s, gt, v_val, var_0) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 +relation evalglobals_is_wf: `%%%%`(v_state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*)) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:174.6-174.18 + rule evalglobals_is_wf_0{v_state : state, var_0 : globaltype*, var_1 : expr*, ret_val : (state, val*), var_2 : (state, val*)}: + `%%%%`(v_state, var_0, var_1, ret_val) + -- wf_state: `%`(v_state) + -- (wf_globaltype: `%`(var_0))*{var_0 <- var_0} + -- (wf_instr: `%`(var_1))*{var_1 <- var_1}*{var_1 <- var_1} + -- if (ret_val = var_2) + -- wf_state: `%`(ret_val.0) + -- (wf_val: `%`(iter))*{iter <- ret_val.1} + -- fun_evalglobals: `%%%%`(v_state, var_0, var_1, var_2) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $instantiate(v_store : store, v_module : module, var_0 : externaddr*) : config +relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $instantiate{s : store, v_module : module, externaddr_lst : externaddr*, xt_I_lst : externtype*, xt_E_lst : externtype*, expr_G_lst : expr*, globaltype_lst : globaltype*, expr_T_lst : expr*, tabletype_lst : tabletype*, byte_lst_lst : byte**, datamode_lst : datamode*, elemmode_lst : elemmode*, expr_E_lst_lst : expr**, reftype_lst : reftype*, x_opt : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat}(s, v_module, externaddr_lst) = `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt)) - -- Module_ok: `|-%:%`(v_module, `%->%`_moduletype(xt_I_lst, xt_E_lst)) - -- (Externaddr_ok: `%|-%:%`(s, externaddr#8, xt_I#2))*{externaddr#8 <- externaddr_lst, xt_I#2 <- xt_I_lst} - -- let{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*} MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst)) = v_module - -- if (global_lst = GLOBAL_global(globaltype#127, expr_G#3)*{expr_G#3 <- expr_G_lst, globaltype#127 <- globaltype_lst}) - -- if (table_lst = TABLE_table(tabletype#161, expr_T#3)*{expr_T#3 <- expr_T_lst, tabletype#161 <- tabletype_lst}) - -- if (data_lst = DATA_data(byte_lst#117, datamode#116)*{byte_lst#117 <- byte_lst_lst, datamode#116 <- datamode_lst}) - -- if (elem_lst = ELEM_elem(reftype#517, expr_E_lst#3, elemmode#237)*{elemmode#237 <- elemmode_lst, expr_E_lst#3 <- expr_E_lst_lst, reftype#517 <- reftype_lst}) - -- if (start_opt = START_start(x#6)?{x#6 <- x_opt}) - -- if (moduleinst_0 = {TYPES $alloctypes(type_lst), TAGS [], GLOBALS $globalsxa(externaddr_lst), MEMS [], TABLES [], FUNCS $funcsxa(externaddr_lst) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) - -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- let{z' : state, val_G_lst : val*} (z', val_G_lst) = $evalglobals(z, globaltype_lst, expr_G_lst) - -- let{z'' : state, ref_T_lst : ref*} (z'', ref_T_lst) = $evalexprs(z', expr_T_lst) - -- let{z''' : state, ref_E_lst_lst : ref**} (z''', ref_E_lst_lst) = $evalexprss(z'', expr_E_lst_lst) - -- let{s''' : store, f : frame} `%;%`_state(s''', f) = z''' - -- let{s'''' : store, v_moduleinst : moduleinst} (s'''', v_moduleinst) = $allocmodule(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst) - -- let{instr_D_lst : instr*} instr_D_lst = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#1), data_lst[i_D#1])^(i_D#1<|data_lst|){}) - -- let{instr_E_lst : instr*} instr_E_lst = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#1), elem_lst[i_E#1])^(i_E#1<|elem_lst|){}) - -- let{instr_S_opt : instr?} instr_S_opt = CALL_instr(x#7)?{x#7 <- x_opt} + rule fun_instantiate_case_0{s : store, v_module : module, externaddr_lst : externaddr*, xt_I_lst : externtype*, xt_E_lst : externtype*, expr_G_lst : expr*, globaltype_lst : globaltype*, expr_T_lst : expr*, tabletype_lst : tabletype*, byte_lst_lst : byte**, datamode_lst : datamode*, elemmode_lst : elemmode*, expr_E_lst_lst : expr**, reftype_lst : reftype*, x_opt : idx?, moduleinst_0 : moduleinst, z : state, i_D : nat, i_E : nat, var_11 : funcaddr*, var_10 : globaladdr*, var_9 : deftype*, var_8_lst : instr**, var_7_lst : instr**, var_6 : (store, moduleinst), var_5 : (state, ref**), var_4 : (state, ref*), var_3 : (state, val*), var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: + `%%%%`(s, v_module, externaddr_lst, mk_config_config(mk_state_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt))) + -- Module_ok: `|-%:%`(v_module, mk_moduletype_moduletype(xt_I_lst, xt_E_lst)) + -- (Externaddr_ok: `%|-%:%`(s, externaddr_8, xt_I_2))*{externaddr_8 <- externaddr_lst, xt_I_2 <- xt_I_lst} + -- if (|externaddr_lst| = |xt_I_lst|) + -- let{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*} MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)) = v_module + -- if (global_lst = GLOBAL_global(globaltype_127, expr_G_3)*{expr_G_3 <- expr_G_lst, globaltype_127 <- globaltype_lst}) + -- if (table_lst = TABLE_table(tabletype_161, expr_T_3)*{expr_T_3 <- expr_T_lst, tabletype_161 <- tabletype_lst}) + -- if (data_lst = DATA_data(byte_lst_117, datamode_116)*{byte_lst_117 <- byte_lst_lst, datamode_116 <- datamode_lst}) + -- if (elem_lst = ELEM_elem(reftype_516, expr_E_lst_3, elemmode_237)*{elemmode_237 <- elemmode_lst, expr_E_lst_3 <- expr_E_lst_lst, reftype_516 <- reftype_lst}) + -- if (start_opt = START_start(x_6)?{x_6 <- x_opt}) + -- if (moduleinst_0 = {TYPES var_0, TAGS [], GLOBALS var_1, MEMS [], TABLES [], FUNCS var_2 ++ (|s.FUNCS_store| + i_F_2)^(i_F_2<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (z = mk_state_state(s, {LOCALS [], MODULE moduleinst_0})) + -- let{z' : state, val_G_lst : val*} (z', val_G_lst) = var_3 + -- let{z'' : state, ref_T_lst : ref*} (z'', ref_T_lst) = var_4 + -- let{z''' : state, ref_E_lst_lst : ref**} (z''', ref_E_lst_lst) = var_5 + -- let{s''' : store, f : frame} mk_state_state(s''', f) = z''' + -- let{s'''' : store, v_moduleinst : moduleinst} (s'''', v_moduleinst) = var_6 + -- let{instr_D_lst : instr*} instr_D_lst = $concat_(syntax instr, var_7_lst) + -- let{instr_E_lst : instr*} instr_E_lst = $concat_(syntax instr, var_8_lst) + -- let{instr_S_opt : instr?} instr_S_opt = CALL_instr(x_7)?{x_7 <- x_opt} -- wf_state: `%`(z) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt))) - -- wf_moduletype: `%`(`%->%`_moduletype(xt_I_lst, xt_E_lst)) - -- wf_module: `%`(MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst))) - -- (wf_global: `%`(GLOBAL_global(globaltype#130, expr_G#5)))*{expr_G#5 <- expr_G_lst, globaltype#130 <- globaltype_lst} - -- (wf_table: `%`(TABLE_table(tabletype#163, expr_T#5)))*{expr_T#5 <- expr_T_lst, tabletype#163 <- tabletype_lst} - -- (wf_data: `%`(DATA_data(byte_lst#119, datamode#118)))*{byte_lst#119 <- byte_lst_lst, datamode#118 <- datamode_lst} - -- (wf_elem: `%`(ELEM_elem(reftype#519, expr_E_lst#5, elemmode#239)))*{elemmode#239 <- elemmode_lst, expr_E_lst#5 <- expr_E_lst_lst, reftype#519 <- reftype_lst} - -- (wf_start: `%`(START_start(x#8)))?{x#8 <- x_opt} - -- wf_moduleinst: `%`({TYPES $alloctypes(type_lst), TAGS [], GLOBALS $globalsxa(externaddr_lst), MEMS [], TABLES [], FUNCS $funcsxa(externaddr_lst) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) - -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- wf_state: `%`(`%;%`_state(s''', f)) - -- (wf_uN: `%%`(32, `%`_uN(i_D#2)))^(i_D#2<|data_lst|){} - -- (wf_uN: `%%`(32, `%`_uN(i_E#2)))^(i_E#2<|elem_lst|){} - -- (wf_instr: `%`(CALL_instr(x#9)))?{x#9 <- x_opt} + -- wf_moduletype: `%`(mk_moduletype_moduletype(xt_I_lst, xt_E_lst)) + -- wf_module: `%`(MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst))) + -- (wf_global: `%`(GLOBAL_global(globaltype_130, expr_G_5)))*{expr_G_5 <- expr_G_lst, globaltype_130 <- globaltype_lst} + -- if (|expr_G_lst| = |globaltype_lst|) + -- (wf_table: `%`(TABLE_table(tabletype_163, expr_T_5)))*{expr_T_5 <- expr_T_lst, tabletype_163 <- tabletype_lst} + -- if (|expr_T_lst| = |tabletype_lst|) + -- (wf_data: `%`(DATA_data(byte_lst_119, datamode_118)))*{byte_lst_119 <- byte_lst_lst, datamode_118 <- datamode_lst} + -- if (|byte_lst_lst| = |datamode_lst|) + -- (wf_elem: `%`(ELEM_elem(reftype_518, expr_E_lst_5, elemmode_239)))*{elemmode_239 <- elemmode_lst, expr_E_lst_5 <- expr_E_lst_lst, reftype_518 <- reftype_lst} + -- if (|elemmode_lst| = |expr_E_lst_lst|) + -- if (|elemmode_lst| = |reftype_lst|) + -- (wf_start: `%`(START_start(x_8)))?{x_8 <- x_opt} + -- wf_moduleinst: `%`({TYPES var_9, TAGS [], GLOBALS var_10, MEMS [], TABLES [], FUNCS var_11 ++ (|s.FUNCS_store| + i_F_3)^(i_F_3<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_state: `%`(mk_state_state(s, {LOCALS [], MODULE moduleinst_0})) + -- wf_state: `%`(mk_state_state(s''', f)) + -- (wf_uN: `%%`(32, mk_uN_uN(i_D_2)))^(i_D_2<|data_lst|){} + -- (wf_uN: `%%`(32, mk_uN_uN(i_E_2)))^(i_E_2<|elem_lst|){} + -- (wf_instr: `%`(CALL_instr(x_9)))?{x_9 <- x_opt} + -- fun_funcsxa: `%%`(externaddr_lst, var_11) + -- fun_globalsxa: `%%`(externaddr_lst, var_10) + -- fun_alloctypes: `%%`(type_lst, var_9) + -- (fun_runelem_: `%%%`(mk_uN_elemidx(i_E_1), elem_lst[i_E_1], var_8))^(i_E_1<|elem_lst|){var_8 <- var_8_lst} + -- (if (i_E_1 < |elem_lst|))^(i_E_1<|elem_lst|){} + -- (fun_rundata_: `%%%`(mk_uN_dataidx(i_D_1), data_lst[i_D_1], var_7))^(i_D_1<|data_lst|){var_7 <- var_7_lst} + -- (if (i_D_1 < |data_lst|))^(i_D_1<|data_lst|){} + -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_6) + -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_5) + -- fun_evalexprs: `%%%`(z', expr_T_lst, var_4) + -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_3) + -- fun_funcsxa: `%%`(externaddr_lst, var_2) + -- fun_globalsxa: `%%`(externaddr_lst, var_1) + -- fun_alloctypes: `%%`(type_lst, var_0) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation instantiate_is_wf: `%%%%`(v_store : store, v_module : module, var_0 : externaddr*, ret_val : config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule instantiate_is_wf_0{v_store : store, v_module : module, var_0 : externaddr*, ret_val : config, var_1 : config}: + `%%%%`(v_store, v_module, var_0, ret_val) + -- wf_store: `%`(v_store) + -- wf_module: `%`(v_module) + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_instantiate: `%%%%`(v_store, v_module, var_0, var_1) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_invoke: `%%%%`(store, funcaddr, val*, config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_invoke_case_0{s : store, v_funcaddr : nat, val_lst : val*, t_1_lst : valtype*, t_2_lst : valtype*}: + `%%%%`(s, v_funcaddr, val_lst, mk_config_config(mk_state_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(v_val)*{v_val <- val_lst} ++ [REF_FUNC_ADDR_instr(v_funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[v_funcaddr].TYPE_funcinst))])) + -- Expand: `%~~%`(s.FUNCS_store[v_funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) + -- if (v_funcaddr < |s.FUNCS_store|) + -- (Val_ok: `%|-%:%`(s, val_2, t_1_5))*{t_1_5 <- t_1_lst, val_2 <- val_lst} + -- if (|t_1_lst| = |val_lst|) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(v_store : store, v_funcaddr : funcaddr, var_0 : val*) : config +relation invoke_is_wf: `%%%%`(v_store : store, v_funcaddr : funcaddr, var_0 : val*, ret_val : config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $invoke{s : store, v_funcaddr : nat, val_lst : val*, t_1_lst : valtype*, t_2_lst : valtype*}(s, v_funcaddr, val_lst) = `%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(v_val)*{v_val <- val_lst} ++ [`REF.FUNC_ADDR`_instr(v_funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[v_funcaddr].TYPE_funcinst))]) - -- Expand: `%~~%`(s.FUNCS_store[v_funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) - -- (Val_ok: `%|-%:%`(s, val#2, t_1#7))*{t_1#7 <- t_1_lst, val#2 <- val_lst} - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#3)*{val#3 <- val_lst} ++ [`REF.FUNC_ADDR`_instr(v_funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[v_funcaddr].TYPE_funcinst))])) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + rule invoke_is_wf_0{v_store : store, v_funcaddr : funcaddr, var_0 : val*, ret_val : config, var_1 : config}: + `%%%%`(v_store, v_funcaddr, var_0, ret_val) + -- wf_store: `%`(v_store) + -- (wf_val: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_config: `%`(ret_val) + -- fun_invoke: `%%%%`(v_store, v_funcaddr, var_0, var_1) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -15236,6 +19982,14 @@ syntax nopt = u32* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec def $ieee_(v_N : N, rat : rat) : fNmag +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +relation ieee__is_wf: `%%%`(v_N : N, rat : rat, ret_val : fNmag) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule ieee__is_wf_0{v_N : N, rat : rat, ret_val : fNmag}: + `%%%`(v_N, rat, ret_val) + -- if (ret_val = $ieee_(v_N, rat)) + -- wf_fNmag: `%%`(v_N, ret_val) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec syntax idctxt = { @@ -15276,13 +20030,30 @@ syntax I = idctxt ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { -;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.1-154.56 -def $concat_idctxt(var_0 : idctxt*) : idctxt - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:155.1-155.29 - def $concat_idctxt([]) = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []} - -- wf_idctxt: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:156.1-156.53 - def $concat_idctxt{v_I : idctxt, I'_lst : I*}([v_I] ++ I'_lst) = v_I +++ $concat_idctxt(I'_lst) +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation fun_concat_idctxt: `%%`(idctxt*, idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_0: + `%%`([], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule fun_concat_idctxt_case_1{v_I : idctxt, I'_lst : I*, var_0 : idctxt}: + `%%`([v_I] ++ I'_lst, v_I +++ var_0) + -- fun_concat_idctxt: `%%`(I'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 +relation concat_idctxt_is_wf: `%%`(var_0 : idctxt*, ret_val : idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec:154.6-154.20 + rule concat_idctxt_is_wf_0{var_0 : idctxt*, ret_val : idctxt, var_1 : idctxt}: + `%%`(var_0, ret_val) + -- (wf_idctxt: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- wf_idctxt: `%`(ret_val) + -- fun_concat_idctxt: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec @@ -15300,10 +20071,21 @@ relation Idctxt_ok: `|-%:OK`(idctxt) -- if $disjoint_(syntax name, $concatopt_(syntax name, v_I.ELEMS_I)) -- if $disjoint_(syntax name, $concatopt_(syntax name, v_I.LOCALS_I)) -- if $disjoint_(syntax name, $concatopt_(syntax name, v_I.LABELS_I)) - -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(`%`_name(field_lst))])))*{field_lst <- field_lst_lst} - -- if ([?(`%`_name(field_lst))*{field_lst <- field_lst_lst}] = v_I.FIELDS_I) + -- (if $disjoint_(syntax name, $concatopt_(syntax name, [?(mk_name_name(field_lst))])))*{field_lst <- field_lst_lst} + -- if ([?(mk_name_name(field_lst))*{field_lst <- field_lst_lst}] = v_I.FIELDS_I) -- wf_idctxt: `%`(v_I) - -- (wf_name: `%`(`%`_name(field_lst)))*{field_lst <- field_lst_lst} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.TYPES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.TAGS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.GLOBALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.MEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.TABLES_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.FUNCS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.DATAS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.ELEMS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.LOCALS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, v_I.LABELS_I)} + -- (wf_name: `%`(iter))*{iter <- $concatopt_(syntax name, [?(mk_name_name(field_lst))])}*{field_lst <- field_lst_lst} + -- (wf_name: `%`(mk_name_name(field_lst)))*{field_lst <- field_lst_lst} ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec def $dots : () @@ -15424,160 +20206,387 @@ relation wf_decl: `%`(decl) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.1-258.76 -def $typesd(var_0 : decl*) : type* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:270.1-270.23 - def $typesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:271.1-271.48 - def $typesd{v_rectype : rectype, decl'_lst : decl*}([TYPE_decl(v_rectype)] ++ decl'_lst) = [TYPE_type(v_rectype)] ++ $typesd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:272.1-272.57 - def $typesd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $typesd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 +relation fun_typesd: `%%`(decl*, type*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_1{v_rectype : rectype, decl'_lst : decl*, var_0 : type*}: + `%%`([TYPE_decl(v_rectype)] ++ decl'_lst, [TYPE_type(v_rectype)] ++ var_0) + -- fun_typesd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:258.6-258.13 + rule fun_typesd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : type*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_typesd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation fun_importsd: `%%`(decl*, import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_1{v_name : name, name_0 : name, v_externtype : externtype, decl'_lst : decl*, var_0 : import*}: + `%%`([IMPORT_decl(v_name, name_0, v_externtype)] ++ decl'_lst, [IMPORT_import(v_name, name_0, v_externtype)] ++ var_0) + -- fun_importsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule fun_importsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : import*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_importsd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 +relation importsd_is_wf: `%%`(var_0 : decl*, ret_val : import*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.6-259.15 + rule importsd_is_wf_0{var_0 : decl*, ret_val : import*, var_1 : import*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_import: `%`(ret_val))*{ret_val <- ret_val} + -- fun_importsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:259.1-259.78 -def $importsd(var_0 : decl*) : import* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:274.1-274.25 - def $importsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:275.1-275.56 - def $importsd{v_name : name, name_0 : name, v_externtype : externtype, decl'_lst : decl*}([IMPORT_decl(v_name, name_0, v_externtype)] ++ decl'_lst) = [IMPORT_import(v_name, name_0, v_externtype)] ++ $importsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:276.1-276.61 - def $importsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $importsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation fun_tagsd: `%%`(decl*, tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_1{v_tagtype : tagtype, decl'_lst : decl*, var_0 : tag*}: + `%%`([TAG_decl(v_tagtype)] ++ decl'_lst, [TAG_tag(v_tagtype)] ++ var_0) + -- fun_tagsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule fun_tagsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : tag*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_tagsd: `%%`(decl'_lst, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.1-260.75 -def $tagsd(var_0 : decl*) : tag* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:278.1-278.22 - def $tagsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:279.1-279.44 - def $tagsd{v_tagtype : tagtype, decl'_lst : decl*}([TAG_decl(v_tagtype)] ++ decl'_lst) = [TAG_tag(v_tagtype)] ++ $tagsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:280.1-280.55 - def $tagsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $tagsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 +relation tagsd_is_wf: `%%`(var_0 : decl*, ret_val : tag*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:260.6-260.12 + rule tagsd_is_wf_0{var_0 : decl*, ret_val : tag*, var_1 : tag*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_tag: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tagsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.1-261.78 -def $globalsd(var_0 : decl*) : global* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:282.1-282.25 - def $globalsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:283.1-283.56 - def $globalsd{v_globaltype : globaltype, v_expr : expr, decl'_lst : decl*}([GLOBAL_decl(v_globaltype, v_expr)] ++ decl'_lst) = [GLOBAL_global(v_globaltype, v_expr)] ++ $globalsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:284.1-284.61 - def $globalsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $globalsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation fun_globalsd: `%%`(decl*, global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_1{v_globaltype : globaltype, v_expr : expr, decl'_lst : decl*, var_0 : global*}: + `%%`([GLOBAL_decl(v_globaltype, v_expr)] ++ decl'_lst, [GLOBAL_global(v_globaltype, v_expr)] ++ var_0) + -- fun_globalsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule fun_globalsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : global*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_globalsd: `%%`(decl'_lst, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.1-262.75 -def $memsd(var_0 : decl*) : mem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:286.1-286.22 - def $memsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:287.1-287.44 - def $memsd{v_memtype : memtype, decl'_lst : decl*}([MEMORY_decl(v_memtype)] ++ decl'_lst) = [MEMORY_mem(v_memtype)] ++ $memsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:288.1-288.55 - def $memsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $memsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 +relation globalsd_is_wf: `%%`(var_0 : decl*, ret_val : global*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:261.6-261.15 + rule globalsd_is_wf_0{var_0 : decl*, ret_val : global*, var_1 : global*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_global: `%`(ret_val))*{ret_val <- ret_val} + -- fun_globalsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.1-263.77 -def $tablesd(var_0 : decl*) : table* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:290.1-290.24 - def $tablesd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:291.1-291.52 - def $tablesd{v_tabletype : tabletype, v_expr : expr, decl'_lst : decl*}([TABLE_decl(v_tabletype, v_expr)] ++ decl'_lst) = [TABLE_table(v_tabletype, v_expr)] ++ $tablesd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:292.1-292.59 - def $tablesd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $tablesd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation fun_memsd: `%%`(decl*, mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_1{v_memtype : memtype, decl'_lst : decl*, var_0 : mem*}: + `%%`([MEMORY_decl(v_memtype)] ++ decl'_lst, [MEMORY_mem(v_memtype)] ++ var_0) + -- fun_memsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule fun_memsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : mem*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_memsd: `%%`(decl'_lst, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.1-264.76 -def $funcsd(var_0 : decl*) : func* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:294.1-294.23 - def $funcsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:295.1-295.48 - def $funcsd{v_typeidx : typeidx, local_lst : local*, v_expr : expr, decl'_lst : decl*}([FUNC_decl(v_typeidx, local_lst, v_expr)] ++ decl'_lst) = [FUNC_func(v_typeidx, local_lst, v_expr)] ++ $funcsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:296.1-296.57 - def $funcsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $funcsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 +relation memsd_is_wf: `%%`(var_0 : decl*, ret_val : mem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:262.6-262.12 + rule memsd_is_wf_0{var_0 : decl*, ret_val : mem*, var_1 : mem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_mem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_memsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.1-265.76 -def $datasd(var_0 : decl*) : data* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:298.1-298.23 - def $datasd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:299.1-299.48 - def $datasd{byte_lst : byte*, v_datamode : datamode, decl'_lst : decl*}([DATA_decl(byte_lst, v_datamode)] ++ decl'_lst) = [DATA_data(byte_lst, v_datamode)] ++ $datasd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:300.1-300.57 - def $datasd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $datasd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation fun_tablesd: `%%`(decl*, table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_1{v_tabletype : tabletype, v_expr : expr, decl'_lst : decl*, var_0 : table*}: + `%%`([TABLE_decl(v_tabletype, v_expr)] ++ decl'_lst, [TABLE_table(v_tabletype, v_expr)] ++ var_0) + -- fun_tablesd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule fun_tablesd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : table*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_tablesd: `%%`(decl'_lst, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.1-266.76 -def $elemsd(var_0 : decl*) : elem* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:302.1-302.23 - def $elemsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:303.1-303.48 - def $elemsd{v_reftype : reftype, expr_lst : expr*, v_elemmode : elemmode, decl'_lst : decl*}([ELEM_decl(v_reftype, expr_lst, v_elemmode)] ++ decl'_lst) = [ELEM_elem(v_reftype, expr_lst, v_elemmode)] ++ $elemsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:304.1-304.57 - def $elemsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $elemsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 +relation tablesd_is_wf: `%%`(var_0 : decl*, ret_val : table*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:263.6-263.14 + rule tablesd_is_wf_0{var_0 : decl*, ret_val : table*, var_1 : table*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_table: `%`(ret_val))*{ret_val <- ret_val} + -- fun_tablesd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.1-267.77 -def $startsd(var_0 : decl*) : start* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:306.1-306.24 - def $startsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:307.1-307.52 - def $startsd{v_funcidx : funcidx, decl'_lst : decl*}([START_decl(v_funcidx)] ++ decl'_lst) = [START_start(v_funcidx)] ++ $startsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:308.1-308.59 - def $startsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $startsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation fun_funcsd: `%%`(decl*, func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_1{v_typeidx : typeidx, local_lst : local*, v_expr : expr, decl'_lst : decl*, var_0 : func*}: + `%%`([FUNC_decl(v_typeidx, local_lst, v_expr)] ++ decl'_lst, [FUNC_func(v_typeidx, local_lst, v_expr)] ++ var_0) + -- fun_funcsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule fun_funcsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : func*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_funcsd: `%%`(decl'_lst, var_0) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rec { -;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.1-268.78 -def $exportsd(var_0 : decl*) : export* - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:310.1-310.25 - def $exportsd([]) = [] - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:311.1-311.56 - def $exportsd{v_name : name, v_externidx : externidx, decl'_lst : decl*}([EXPORT_decl(v_name, v_externidx)] ++ decl'_lst) = [EXPORT_export(v_name, v_externidx)] ++ $exportsd(decl'_lst) - ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:312.1-312.61 - def $exportsd{v_decl : decl, decl'_lst : decl*}([v_decl] ++ decl'_lst) = $exportsd(decl'_lst) +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 +relation funcsd_is_wf: `%%`(var_0 : decl*, ret_val : func*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:264.6-264.13 + rule funcsd_is_wf_0{var_0 : decl*, ret_val : func*, var_1 : func*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_func: `%`(ret_val))*{ret_val <- ret_val} + -- fun_funcsd: `%%`(var_0, var_1) } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(var_0 : decl*) : bool +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation fun_datasd: `%%`(decl*, data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_1{byte_lst : byte*, v_datamode : datamode, decl'_lst : decl*, var_0 : data*}: + `%%`([DATA_decl(byte_lst, v_datamode)] ++ decl'_lst, [DATA_data(byte_lst, v_datamode)] ++ var_0) + -- fun_datasd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule fun_datasd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : data*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_datasd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 +relation datasd_is_wf: `%%`(var_0 : decl*, ret_val : data*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:265.6-265.13 + rule datasd_is_wf_0{var_0 : decl*, ret_val : data*, var_1 : data*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_data: `%`(ret_val))*{ret_val <- ret_val} + -- fun_datasd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation fun_elemsd: `%%`(decl*, elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_1{v_reftype : reftype, expr_lst : expr*, v_elemmode : elemmode, decl'_lst : decl*, var_0 : elem*}: + `%%`([ELEM_decl(v_reftype, expr_lst, v_elemmode)] ++ decl'_lst, [ELEM_elem(v_reftype, expr_lst, v_elemmode)] ++ var_0) + -- fun_elemsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule fun_elemsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : elem*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_elemsd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 +relation elemsd_is_wf: `%%`(var_0 : decl*, ret_val : elem*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:266.6-266.13 + rule elemsd_is_wf_0{var_0 : decl*, ret_val : elem*, var_1 : elem*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_elem: `%`(ret_val))*{ret_val <- ret_val} + -- fun_elemsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation fun_startsd: `%%`(decl*, start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_1{v_funcidx : funcidx, decl'_lst : decl*, var_0 : start*}: + `%%`([START_decl(v_funcidx)] ++ decl'_lst, [START_start(v_funcidx)] ++ var_0) + -- fun_startsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule fun_startsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : start*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_startsd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 +relation startsd_is_wf: `%%`(var_0 : decl*, ret_val : start*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:267.6-267.14 + rule startsd_is_wf_0{var_0 : decl*, ret_val : start*, var_1 : start*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_start: `%`(ret_val))*{ret_val <- ret_val} + -- fun_startsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation fun_exportsd: `%%`(decl*, export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_0: + `%%`([], []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_1{v_name : name, v_externidx : externidx, decl'_lst : decl*, var_0 : export*}: + `%%`([EXPORT_decl(v_name, v_externidx)] ++ decl'_lst, [EXPORT_export(v_name, v_externidx)] ++ var_0) + -- fun_exportsd: `%%`(decl'_lst, var_0) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule fun_exportsd_case_2{v_decl : decl, decl'_lst : decl*, var_0 : export*}: + `%%`([v_decl] ++ decl'_lst, var_0) + -- fun_exportsd: `%%`(decl'_lst, var_0) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +rec { + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 +relation exportsd_is_wf: `%%`(var_0 : decl*, ret_val : export*) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec:268.6-268.15 + rule exportsd_is_wf_0{var_0 : decl*, ret_val : export*, var_1 : export*}: + `%%`(var_0, ret_val) + -- (wf_decl: `%`(var_0))*{var_0 <- var_0} + -- if (ret_val = var_1) + -- (wf_export: `%`(ret_val))*{ret_val <- ret_val} + -- fun_exportsd: `%%`(var_0, var_1) +} + +;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec +relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{decl_lst : decl*}(decl_lst) = true - -- if ($importsd(decl_lst) = []) + rule fun_ordered_case_0{decl_lst : decl*, var_0 : import*}: + `%%`(decl_lst, true) + -- if (var_0 = []) + -- fun_importsd: `%%`(decl_lst, var_0) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{v_name : name, name_0 : name, v_externtype : externtype, decl_1_lst : decl*, decl_2_lst : decl*}(decl_1_lst ++ [IMPORT_decl(v_name, name_0, v_externtype)] ++ decl_2_lst) = (((((($importsd(decl_1_lst) = []) /\ ($tagsd(decl_1_lst) = [])) /\ ($globalsd(decl_1_lst) = [])) /\ ($memsd(decl_1_lst) = [])) /\ ($tablesd(decl_1_lst) = [])) /\ ($funcsd(decl_1_lst) = [])) + rule fun_ordered_case_1{v_name : name, name_0 : name, v_externtype : externtype, decl_1_lst : decl*, decl_2_lst : decl*, var_5 : func*, var_4 : table*, var_3 : mem*, var_2 : global*, var_1 : tag*, var_0 : import*}: + `%%`(decl_1_lst ++ [IMPORT_decl(v_name, name_0, v_externtype)] ++ decl_2_lst, ((((((var_0 = []) /\ (var_1 = [])) /\ (var_2 = [])) /\ (var_3 = [])) /\ (var_4 = [])) /\ (var_5 = []))) + -- fun_funcsd: `%%`(decl_1_lst, var_5) + -- fun_tablesd: `%%`(decl_1_lst, var_4) + -- fun_memsd: `%%`(decl_1_lst, var_3) + -- fun_globalsd: `%%`(decl_1_lst, var_2) + -- fun_tagsd: `%%`(decl_1_lst, var_1) + -- fun_importsd: `%%`(decl_1_lst, var_0) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec rule mk_Context_ok{C : context, v_n : n, dt_lst : deftype*, jt_lst : tagtype*, gt_lst : globaltype*, mt_lst : memtype*, tt_lst : tabletype*, dt_F_lst : deftype*, ok_lst : datatype*, et_lst : elemtype*, lct_lst : localtype*, rt_lst : reftype*, rt'_opt : reftype?, x_lst : idx*, v_m : m, st_lst : subtype*, C_0 : context, t_1_lst : valtype*, t_2_lst : valtype*}: `|-%:OK`(C) - -- if (C = {TYPES dt_lst, TAGS jt_lst, GLOBALS gt_lst, MEMS mt_lst, TABLES tt_lst, FUNCS dt_F_lst, DATAS ok_lst, ELEMS et_lst, LOCALS lct_lst, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- rt_lst})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- rt'_opt}))), REFS x_lst, RECS st_lst}) + -- if (C = {TYPES dt_lst, TAGS jt_lst, GLOBALS gt_lst, MEMS mt_lst, TABLES tt_lst, FUNCS dt_F_lst, DATAS ok_lst, ELEMS et_lst, LOCALS lct_lst, LABELS [mk_list_resulttype($valtype_reftype(rt)*{rt <- rt_lst})], RETURN ?(mk_list_resulttype(lift($valtype_reftype(rt')?{rt' <- rt'_opt}))), REFS x_lst, RECS st_lst}) -- if (C_0 = {TYPES dt_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (Deftype_ok: `%|-%:OK`({TYPES dt_lst[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt))^(i%`_comptype(mk_list_resulttype([t_1]), mk_list_resulttype([t_2]))))*{dt_F <- dt_F_lst, t_1 <- t_1_lst, t_2 <- t_2_lst} -- if (|dt_F_lst| = |t_1_lst|) -- if (|dt_F_lst| = |t_2_lst|) - -- (Expand: `%~~%`(dt_F, `FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{dt_F <- dt_F_lst, t_1 <- t_1_lst, t_2 <- t_2_lst} -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- et_lst} -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- lct_lst} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt)])))*{rt <- rt_lst} - -- (Resulttype_ok: `%|-%:OK`(C_0, `%`_resulttype([$valtype_reftype(rt')])))?{rt' <- rt'_opt} + -- (Resulttype_ok: `%|-%:OK`(C_0, mk_list_resulttype([$valtype_reftype(rt)])))*{rt <- rt_lst} + -- (Resulttype_ok: `%|-%:OK`(C_0, mk_list_resulttype([$valtype_reftype(rt')])))?{rt' <- rt'_opt} -- (if ($proj_uN_0(x).0 < |dt_F_lst|))*{x <- x_lst} -- wf_context: `%`(C) -- wf_context: `%`(C_0) - -- wf_context: `%`({TYPES dt_lst, TAGS jt_lst, GLOBALS gt_lst, MEMS mt_lst, TABLES tt_lst, FUNCS dt_F_lst, DATAS ok_lst, ELEMS et_lst, LOCALS lct_lst, LABELS [`%`_resulttype($valtype_reftype(rt)*{rt <- rt_lst})], RETURN ?(`%`_resulttype(lift($valtype_reftype(rt')?{rt' <- rt'_opt}))), REFS x_lst, RECS st_lst}) + -- wf_context: `%`({TYPES dt_lst, TAGS jt_lst, GLOBALS gt_lst, MEMS mt_lst, TABLES tt_lst, FUNCS dt_F_lst, DATAS ok_lst, ELEMS et_lst, LOCALS lct_lst, LABELS [mk_list_resulttype($valtype_reftype(rt)*{rt <- rt_lst})], RETURN ?(mk_list_resulttype(lift($valtype_reftype(rt')?{rt' <- rt'_opt}))), REFS x_lst, RECS st_lst}) -- wf_context: `%`({TYPES dt_lst, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_context: `%`({TYPES dt_lst[0 : i], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}))^(i%`_comptype(mk_list_resulttype([t_1]), mk_list_resulttype([t_2]))))*{t_1 <- t_1_lst, t_2 <- t_2_lst} -- if (|t_1_lst| = |t_2_lst|) - -- (wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- t_1_lst, t_2 <- t_2_lst} + -- if (v_n = |dt_lst|) + -- if (v_m = |st_lst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Localval_ok: `%|-%:%`(store, val?, localtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule set{s : store, v_val : val, t : valtype}: - `%|-%:%`(s, ?(v_val), `%%`_localtype(SET_init, t)) + `%|-%:%`(s, ?(v_val), mk_localtype_localtype(SET_init, t)) -- Val_ok: `%|-%:%`(s, v_val, t) -- wf_store: `%`(s) -- wf_val: `%`(v_val) - -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) + -- wf_localtype: `%`(mk_localtype_localtype(SET_init, t)) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule unset{s : store}: - `%|-%:%`(s, ?(), `%%`_localtype(UNSET_init, BOT_valtype)) + `%|-%:%`(s, ?(), mk_localtype_localtype(UNSET_init, BOT_valtype)) -- wf_store: `%`(s) - -- wf_localtype: `%`(`%%`_localtype(UNSET_init, BOT_valtype)) + -- wf_localtype: `%`(mk_localtype_localtype(UNSET_init, BOT_valtype)) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Datainst_ok: `%|-%:%`(store, datainst, datatype) @@ -15653,31 +20663,31 @@ relation Exportinst_ok: `%|-%:OK`(store, exportinst) relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Moduleinst_ok{s : store, deftype_lst : deftype*, tagaddr_lst : tagaddr*, globaladdr_lst : globaladdr*, memaddr_lst : memaddr*, tableaddr_lst : tableaddr*, funcaddr_lst : funcaddr*, dataaddr_lst : dataaddr*, elemaddr_lst : elemaddr*, exportinst_lst : exportinst*, tagtype_lst : tagtype*, globaltype_lst : globaltype*, memtype_lst : memtype*, tabletype_lst : tabletype*, deftype_F_lst : deftype*, datatype_lst : datatype*, elemtype_lst : elemtype*, subtype_lst : subtype*}: - `%|-%:%`(s, {TYPES deftype_lst, TAGS tagaddr_lst, GLOBALS globaladdr_lst, MEMS memaddr_lst, TABLES tableaddr_lst, FUNCS funcaddr_lst, DATAS dataaddr_lst, ELEMS elemaddr_lst, EXPORTS exportinst_lst}, {TYPES deftype_lst, TAGS tagtype_lst, GLOBALS globaltype_lst, MEMS memtype_lst, TABLES tabletype_lst, FUNCS deftype_F_lst, DATAS datatype_lst, ELEMS elemtype_lst, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr_lst|){}, RECS subtype_lst}) + `%|-%:%`(s, {TYPES deftype_lst, TAGS tagaddr_lst, GLOBALS globaladdr_lst, MEMS memaddr_lst, TABLES tableaddr_lst, FUNCS funcaddr_lst, DATAS dataaddr_lst, ELEMS elemaddr_lst, EXPORTS exportinst_lst}, {TYPES deftype_lst, TAGS tagtype_lst, GLOBALS globaltype_lst, MEMS memtype_lst, TABLES tabletype_lst, FUNCS deftype_F_lst, DATAS datatype_lst, ELEMS elemtype_lst, LOCALS [], LABELS [], RETURN ?(), REFS mk_uN_funcidx(i)^(i<|funcaddr_lst|){}, RECS subtype_lst}) -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, v_deftype))*{v_deftype <- deftype_lst} - -- if (|tagaddr_lst| = |tagtype_lst|) -- (Externaddr_ok: `%|-%:%`(s, TAG_externaddr(v_tagaddr), TAG_externtype(v_tagtype)))*{v_tagaddr <- tagaddr_lst, v_tagtype <- tagtype_lst} - -- if (|globaladdr_lst| = |globaltype_lst|) + -- if (|tagaddr_lst| = |tagtype_lst|) -- (Externaddr_ok: `%|-%:%`(s, GLOBAL_externaddr(v_globaladdr), GLOBAL_externtype(v_globaltype)))*{v_globaladdr <- globaladdr_lst, v_globaltype <- globaltype_lst} - -- if (|deftype_F_lst| = |funcaddr_lst|) + -- if (|globaladdr_lst| = |globaltype_lst|) -- (Externaddr_ok: `%|-%:%`(s, FUNC_externaddr(v_funcaddr), FUNC_externtype($typeuse_deftype(deftype_F))))*{deftype_F <- deftype_F_lst, v_funcaddr <- funcaddr_lst} - -- if (|memaddr_lst| = |memtype_lst|) + -- if (|deftype_F_lst| = |funcaddr_lst|) -- (Externaddr_ok: `%|-%:%`(s, MEM_externaddr(v_memaddr), MEM_externtype(v_memtype)))*{v_memaddr <- memaddr_lst, v_memtype <- memtype_lst} - -- if (|tableaddr_lst| = |tabletype_lst|) + -- if (|memaddr_lst| = |memtype_lst|) -- (Externaddr_ok: `%|-%:%`(s, TABLE_externaddr(v_tableaddr), TABLE_externtype(v_tabletype)))*{v_tableaddr <- tableaddr_lst, v_tabletype <- tabletype_lst} + -- if (|tableaddr_lst| = |tabletype_lst|) + -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[v_dataaddr], v_datatype))*{v_dataaddr <- dataaddr_lst, v_datatype <- datatype_lst} -- if (|dataaddr_lst| = |datatype_lst|) -- (if (v_dataaddr < |s.DATAS_store|))*{v_dataaddr <- dataaddr_lst} - -- (Datainst_ok: `%|-%:%`(s, s.DATAS_store[v_dataaddr], v_datatype))*{v_dataaddr <- dataaddr_lst, v_datatype <- datatype_lst} + -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[v_elemaddr], v_elemtype))*{v_elemaddr <- elemaddr_lst, v_elemtype <- elemtype_lst} -- if (|elemaddr_lst| = |elemtype_lst|) -- (if (v_elemaddr < |s.ELEMS_store|))*{v_elemaddr <- elemaddr_lst} - -- (Eleminst_ok: `%|-%:%`(s, s.ELEMS_store[v_elemaddr], v_elemtype))*{v_elemaddr <- elemaddr_lst, v_elemtype <- elemtype_lst} -- (Exportinst_ok: `%|-%:OK`(s, v_exportinst))*{v_exportinst <- exportinst_lst} -- if $disjoint_(syntax name, v_exportinst.NAME_exportinst*{v_exportinst <- exportinst_lst}) - -- if (|TAG_externaddr(v_tagaddr)*{v_tagaddr <- tagaddr_lst} ++ GLOBAL_externaddr(v_globaladdr)*{v_globaladdr <- globaladdr_lst} ++ MEM_externaddr(v_memaddr)*{v_memaddr <- memaddr_lst} ++ TABLE_externaddr(v_tableaddr)*{v_tableaddr <- tableaddr_lst} ++ FUNC_externaddr(v_funcaddr)*{v_funcaddr <- funcaddr_lst}| > 0) -- (if (v_exportinst.ADDR_exportinst <- TAG_externaddr(v_tagaddr)*{v_tagaddr <- tagaddr_lst} ++ GLOBAL_externaddr(v_globaladdr)*{v_globaladdr <- globaladdr_lst} ++ MEM_externaddr(v_memaddr)*{v_memaddr <- memaddr_lst} ++ TABLE_externaddr(v_tableaddr)*{v_tableaddr <- tableaddr_lst} ++ FUNC_externaddr(v_funcaddr)*{v_funcaddr <- funcaddr_lst}))*{v_exportinst <- exportinst_lst} + -- if (|TAG_externaddr(v_tagaddr)*{v_tagaddr <- tagaddr_lst} ++ GLOBAL_externaddr(v_globaladdr)*{v_globaladdr <- globaladdr_lst} ++ MEM_externaddr(v_memaddr)*{v_memaddr <- memaddr_lst} ++ TABLE_externaddr(v_tableaddr)*{v_tableaddr <- tableaddr_lst} ++ FUNC_externaddr(v_funcaddr)*{v_funcaddr <- funcaddr_lst}| > 0) -- wf_store: `%`(s) -- wf_moduleinst: `%`({TYPES deftype_lst, TAGS tagaddr_lst, GLOBALS globaladdr_lst, MEMS memaddr_lst, TABLES tableaddr_lst, FUNCS funcaddr_lst, DATAS dataaddr_lst, ELEMS elemaddr_lst, EXPORTS exportinst_lst}) - -- wf_context: `%`({TYPES deftype_lst, TAGS tagtype_lst, GLOBALS globaltype_lst, MEMS memtype_lst, TABLES tabletype_lst, FUNCS deftype_F_lst, DATAS datatype_lst, ELEMS elemtype_lst, LOCALS [], LABELS [], RETURN ?(), REFS `%`_funcidx(i)^(i<|funcaddr_lst|){}, RECS subtype_lst}) + -- wf_context: `%`({TYPES deftype_lst, TAGS tagtype_lst, GLOBALS globaltype_lst, MEMS memtype_lst, TABLES tabletype_lst, FUNCS deftype_F_lst, DATAS datatype_lst, ELEMS elemtype_lst, LOCALS [], LABELS [], RETURN ?(), REFS mk_uN_funcidx(i)^(i<|funcaddr_lst|){}, RECS subtype_lst}) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- (wf_externtype: `%`(TAG_externtype(v_tagtype)))*{v_tagtype <- tagtype_lst} -- (wf_externtype: `%`(GLOBAL_externtype(v_globaltype)))*{v_globaltype <- globaltype_lst} @@ -15691,8 +20701,8 @@ relation Frame_ok: `%|-%:%`(store, frame, context) rule mk_Frame_ok{s : store, val_opt_lst : val?*, v_moduleinst : moduleinst, C : context, lct_lst : localtype*}: `%|-%:%`(s, {LOCALS val_opt_lst, MODULE v_moduleinst}, C +++ {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS lct_lst, LABELS [], RETURN ?(), REFS [], RECS []}) -- Moduleinst_ok: `%|-%:%`(s, v_moduleinst, C) - -- if (|lct_lst| = |val_opt_lst|) -- (Localval_ok: `%|-%:%`(s, val_opt, lct))*{lct <- lct_lst, val_opt <- val_opt_lst} + -- if (|lct_lst| = |val_opt_lst|) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_frame: `%`({LOCALS val_opt_lst, MODULE v_moduleinst}) @@ -15705,94 +20715,98 @@ rec { relation Instr_ok2: `%;%|-%:%`(store, context, instr, instrtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:10.1-12.46 rule plain{s : store, C : context, v_instr : instr, t_1_lst : valtype*, x_lst : idx*, t_2_lst : valtype*}: - `%;%|-%:%`(s, C, v_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) - -- Instr_ok: `%|-%:%`(C, v_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + `%;%|-%:%`(s, C, v_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) + -- Instr_ok: `%|-%:%`(C, v_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(v_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:14.1-16.27 rule ref{s : store, C : context, v_ref : ref, rt : reftype}: - `%;%|-%:%`(s, C, $instr_ref(v_ref), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) + `%;%|-%:%`(s, C, $instr_ref(v_ref), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_reftype(rt)]))) -- Ref_ok: `%|-%:%`(s, v_ref, rt) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_ref: `%`(v_ref) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([$valtype_reftype(rt)]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:18.1-21.68 rule label{s : store, C : context, v_n : n, instr'_lst : instr*, instr_lst : instr*, t_lst : valtype*, t'_lst : valtype*, x'_lst : idx*, x_lst : idx*}: - `%;%|-%:%`(s, C, `LABEL_%{%}%`_instr(v_n, instr'_lst, instr_lst), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr'_lst, `%->_%%`_instrtype(`%`_resulttype(t'_lst), x'_lst, `%`_resulttype(t_lst))) - -- Instrs_ok2: `%;%|-%:%`(s, {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, `%->_%%`_instrtype(`%`_resulttype([]), x_lst, `%`_resulttype(t_lst))) + `%;%|-%:%`(s, C, `LABEL_%{%}%`_instr(v_n, instr'_lst, instr_lst), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr'_lst, mk_instrtype_instrtype(mk_list_resulttype(t'_lst), x'_lst, mk_list_resulttype(t_lst))) + -- Instrs_ok2: `%;%|-%:%`(s, {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t'_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype([]), x_lst, mk_list_resulttype(t_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(`LABEL_%{%}%`_instr(v_n, instr'_lst, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t'_lst), x'_lst, `%`_resulttype(t_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t'_lst)], RETURN ?(), REFS [], RECS []}) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), x_lst, `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t'_lst), x'_lst, mk_list_resulttype(t_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t'_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), x_lst, mk_list_resulttype(t_lst))) + -- if (v_n = |t'_lst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:23.1-26.37 rule frame{s : store, C : context, v_n : n, f : frame, instr_lst : instr*, t_lst : valtype*, C' : context}: - `%;%|-%:%`(s, C, `FRAME_%{%}%`_instr(v_n, f, instr_lst), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + `%;%|-%:%`(s, C, `FRAME_%{%}%`_instr(v_n, f, instr_lst), mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) -- Frame_ok: `%|-%:%`(s, f, C') - -- Expr_ok2: `%;%|-%:%`(s, C', instr_lst, `%`_resulttype(t_lst)) + -- Expr_ok2: `%;%|-%:%`(s, C', instr_lst, mk_list_resulttype(t_lst)) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_context: `%`(C') -- wf_instr: `%`(`FRAME_%{%}%`_instr(v_n, f, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) + -- if (v_n = |t_lst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:28.1-31.52 rule handler{s : store, C : context, v_n : n, catch_lst : catch*, instr_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*, x_lst : idx*}: - `%;%|-%:%`(s, C, `HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst), `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%;%|-%:%`(s, C, `HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst), mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- (Catch_ok: `%|-%:OK`(C, v_catch))*{v_catch <- catch_lst} - -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(`HANDLER_%{%}%`_instr(v_n, catch_lst, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:33.1-35.42 rule trap{s : store, C : context, t_1_lst : valtype*, t_2_lst : valtype*}: - `%;%|-%:%`(s, C, TRAP_instr, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%;%|-%:%`(s, C, TRAP_instr, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Instrtype_ok: `%|-%:OK`(C, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(TRAP_instr) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:5.1-6.36 relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:38.1-39.27 rule empty{s : store, C : context}: - `%;%|-%:%`(s, C, [], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + `%;%|-%:%`(s, C, [], mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) -- wf_store: `%`(s) -- wf_context: `%`(C) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:41.1-45.86 - rule seq{s : store, C : context, instr_1 : instr, instr_2_lst : instr*, t_1_lst : valtype*, x_1_lst : idx*, x_2_lst : idx*, t_3_lst : valtype*, t_2_lst : valtype*, init_lst : init*, t_lst : valtype*}: - `%;%|-%:%`(s, C, [instr_1] ++ instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) - -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) + rule seq{s : store, C : context, instr_1 : instr, instr_2_lst : instr*, t_1_lst : valtype*, x_1_lst : idx*, x_2_lst : idx*, t_3_lst : valtype*, t_2_lst : valtype*, init_lst : init*, t_lst : valtype*, var_0 : context?}: + `%;%|-%:%`(s, C, [instr_1] ++ instr_2_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst ++ x_2_lst, mk_list_resulttype(t_3_lst))) + -- Instr_ok2: `%;%|-%:%`(s, C, instr_1, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = mk_localtype_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst, x_1 <- x_1_lst} -- if (|init_lst| = |t_lst|) -- if (|init_lst| = |x_1_lst|) -- (if ($proj_uN_0(x_1).0 < |C.LOCALS_context|))*{x_1 <- x_1_lst} - -- (if (C.LOCALS_context[$proj_uN_0(x_1).0] = `%%`_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst, x_1 <- x_1_lst} - -- if ($with_locals(C, x_1_lst, `%%`_localtype(SET_init, t)*{t <- t_lst}) =/= ?()) - -- Instrs_ok2: `%;%|-%:%`(s, !($with_locals(C, x_1_lst, `%%`_localtype(SET_init, t)*{t <- t_lst})), instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- Instrs_ok2: `%;%|-%:%`(s, !(var_0), instr_2_lst, mk_instrtype_instrtype(mk_list_resulttype(t_2_lst), x_2_lst, mk_list_resulttype(t_3_lst))) + -- if (var_0 =/= ?()) -- wf_store: `%`(s) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) -- (wf_instr: `%`(instr_2))*{instr_2 <- instr_2_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst, `%`_resulttype(t_2_lst))) - -- (wf_localtype: `%`(`%%`_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst} - -- (wf_localtype: `%`(`%%`_localtype(SET_init, t)))*{t <- t_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- wf_context: `%`(!(var_0)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst ++ x_2_lst, mk_list_resulttype(t_3_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_1_lst, mk_list_resulttype(t_2_lst))) + -- (wf_localtype: `%`(mk_localtype_localtype(v_init, t)))*{v_init <- init_lst, t <- t_lst} + -- (wf_localtype: `%`(mk_localtype_localtype(SET_init, t)))*{t <- t_lst} + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_2_lst), x_2_lst, mk_list_resulttype(t_3_lst))) + -- fun_with_locals: `%%%%`(C, x_1_lst, mk_localtype_localtype(SET_init, t)*{t <- t_lst}, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 rule sub{s : store, C : context, instr_lst : instr*, it' : instrtype, it : instrtype}: @@ -15808,25 +20822,25 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:54.1-57.33 rule frame{s : store, C : context, instr_lst : instr*, t_lst : valtype*, t_1_lst : valtype*, x_lst : idx*, t_2_lst : valtype*}: - `%;%|-%:%`(s, C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_lst ++ t_1_lst), x_lst, `%`_resulttype(t_lst ++ t_2_lst))) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) - -- Resulttype_ok: `%|-%:OK`(C, `%`_resulttype(t_lst)) + `%;%|-%:%`(s, C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ t_1_lst), x_lst, mk_list_resulttype(t_lst ++ t_2_lst))) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) + -- Resulttype_ok: `%|-%:OK`(C, mk_list_resulttype(t_lst)) -- wf_store: `%`(s) -- wf_context: `%`(C) -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ t_1_lst), x_lst, `%`_resulttype(t_lst ++ t_2_lst))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_lst, `%`_resulttype(t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_lst ++ t_1_lst), x_lst, mk_list_resulttype(t_lst ++ t_2_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), x_lst, mk_list_resulttype(t_2_lst))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:7.1-8.36 relation Expr_ok2: `%;%|-%:%`(store, context, expr, resulttype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:60.1-62.44 rule mk_Expr_ok2{s : store, C : context, instr_lst : instr*, t_lst : valtype*}: - `%;%|-%:%`(s, C, instr_lst, `%`_resulttype(t_lst)) - -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + `%;%|-%:%`(s, C, instr_lst, mk_list_resulttype(t_lst)) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t_lst))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype(t_lst))) } ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -15843,37 +20857,37 @@ relation Taginst_ok: `%|-%:%`(store, taginst, tagtype) relation Globalinst_ok: `%|-%:%`(store, globalinst, globaltype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Globalinst_ok{s : store, mut_opt : mut?, t : valtype, v_val : val}: - `%|-%:%`(s, {TYPE `%%`_globaltype(mut_opt, t), VALUE v_val}, `%%`_globaltype(mut_opt, t)) - -- Globaltype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%`_globaltype(mut_opt, t)) + `%|-%:%`(s, {TYPE mk_globaltype_globaltype(mut_opt, t), VALUE v_val}, mk_globaltype_globaltype(mut_opt, t)) + -- Globaltype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, mk_globaltype_globaltype(mut_opt, t)) -- Val_ok: `%|-%:%`(s, v_val, t) -- wf_store: `%`(s) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut_opt, t), VALUE v_val}) - -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, t)) + -- wf_globalinst: `%`({TYPE mk_globaltype_globaltype(mut_opt, t), VALUE v_val}) + -- wf_globaltype: `%`(mk_globaltype_globaltype(mut_opt, t)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Meminst_ok: `%|-%:%`(store, meminst, memtype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Meminst_ok{s : store, at : addrtype, v_n : n, v_m : m, b_lst : byte*}: - `%|-%:%`(s, {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))), BYTES b_lst}, `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))))) - -- Memtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))))) + `%|-%:%`(s, {TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))), BYTES b_lst}, `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))))) + -- Memtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))))) -- if (|b_lst| = (v_n * (64 * $Ki))) -- wf_store: `%`(s) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))), BYTES b_lst}) - -- wf_memtype: `%`(`%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))))) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))), BYTES b_lst}) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Tableinst_ok: `%|-%:%`(store, tableinst, tabletype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Tableinst_ok{s : store, at : addrtype, v_n : n, v_m : m, rt : reftype, ref_lst : ref*}: - `%|-%:%`(s, {TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt), REFS ref_lst}, `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt)) - -- Tabletype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt)) + `%|-%:%`(s, {TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt), REFS ref_lst}, mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt)) + -- Tabletype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt)) -- if (|ref_lst| = v_n) -- (Ref_ok: `%|-%:%`(s, v_ref, rt))*{v_ref <- ref_lst} -- wf_store: `%`(s) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt), REFS ref_lst}) - -- wf_tabletype: `%`(`%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt)) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt), REFS ref_lst}) + -- wf_tabletype: `%`(mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -15895,37 +20909,37 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Structinst_ok{s : store, dt : deftype, fv_lst : fieldval*, mut_opt_lst : mut?*, zt_lst : storagetype*}: `%|-%:OK`(s, {TYPE dt, FIELDS fv_lst}) - -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) - -- if (|fv_lst| = |zt_lst|) + -- Expand: `%~~%`(dt, STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- fv_lst, zt <- zt_lst} + -- if (|fv_lst| = |zt_lst|) -- wf_store: `%`(s) -- wf_structinst: `%`({TYPE dt, FIELDS fv_lst}) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Arrayinst_ok: `%|-%:OK`(store, arrayinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Arrayinst_ok{s : store, dt : deftype, fv_lst : fieldval*, mut_opt : mut?, zt : storagetype}: `%|-%:OK`(s, {TYPE dt, FIELDS fv_lst}) - -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- Expand: `%~~%`(dt, ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- fv_lst} -- wf_store: `%`(s) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv_lst}) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Exninst_ok: `%|-%:OK`(store, exninst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Exninst_ok{s : store, ta : tagaddr, val_lst : val*, dt : deftype, t_lst : valtype*}: `%|-%:OK`(s, {TAG ta, FIELDS val_lst}) - -- if (ta < |s.TAGS_store|) -- if ($typeuse_deftype(dt) = s.TAGS_store[ta].TYPE_taginst) - -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- if (|t_lst| = |val_lst|) + -- if (ta < |s.TAGS_store|) + -- Expand: `%~~%`(dt, `FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) -- (Val_ok: `%|-%:%`(s, v_val, t))*{t <- t_lst, v_val <- val_lst} + -- if (|t_lst| = |val_lst|) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val_lst}) - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(mk_list_resulttype(t_lst), mk_list_resulttype([]))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rec { @@ -15944,86 +20958,97 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:227.1-230.20 rule ref_struct{a : addr, s : store, i : nat, ft_lst : fieldtype*, zt : storagetype}: - `%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) - -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) + `%>>_%%`(REF_STRUCT_ADDR_fieldval(a), s, s.STRUCTS_store[a].FIELDS_structinst[i]) + -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(mk_list_list(ft_lst))) -- if (a < |s.STRUCTS_store|) - -- Expand: `%~~%`(s.STRUCTS_store[a].TYPE_structinst, STRUCT_comptype(`%`_list(ft_lst))) + -- if (ft_lst[i] = mk_fieldtype_fieldtype(?(), zt)) -- if (i < |ft_lst|) - -- if (ft_lst[i] = `%%`_fieldtype(?(), zt)) -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_lst))) - -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) + -- wf_fieldval: `%`(REF_STRUCT_ADDR_fieldval(a)) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(ft_lst))) + -- wf_fieldtype: `%`(mk_fieldtype_fieldtype(?(), zt)) + -- if (i < |s.STRUCTS_store[a].FIELDS_structinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:232.1-234.42 rule ref_array{a : addr, s : store, i : nat, zt : storagetype}: - `%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) - -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) + `%>>_%%`(REF_ARRAY_ADDR_fieldval(a), s, s.ARRAYS_store[a].FIELDS_arrayinst[i]) + -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(mk_fieldtype_fieldtype(?(), zt))) -- if (a < |s.ARRAYS_store|) - -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, ARRAY_comptype(`%%`_fieldtype(?(), zt))) -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- wf_fieldval: `%`(REF_ARRAY_ADDR_fieldval(a)) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(?(), zt))) + -- if (i < |s.ARRAYS_store[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:236.1-237.44 rule ref_exn{a : addr, s : store, i : nat}: - `%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) + `%>>_%%`(REF_EXN_ADDR_fieldval(a), s, $fieldval_val(s.EXNS_store[a].FIELDS_exninst[i])) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(REF_EXN_ADDR_fieldval(a)) -- if (i < |s.EXNS_store[a].FIELDS_exninst|) -- if (a < |s.EXNS_store|) - -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:239.1-240.28 rule ref_extern{v_ref : ref, s : store}: - `%>>_%%`(`REF.EXTERN`_fieldval(v_ref), s, $fieldval_ref(v_ref)) + `%>>_%%`(REF_EXTERN_fieldval(v_ref), s, $fieldval_ref(v_ref)) -- wf_store: `%`(s) - -- wf_fieldval: `%`(`REF.EXTERN`_fieldval(v_ref)) + -- wf_fieldval: `%`(REF_EXTERN_fieldval(v_ref)) } ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec -def $fun_NotImmutReachable(v_fieldval : fieldval, v_store : store, v_fieldval_0 : fieldval) : bool +relation fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fieldval, store, fieldval) + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%`(fv_1, s, fv_2) + -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +relation fun_NotImmutReachable: `%%%%`(fieldval, store, fieldval, bool) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $fun_NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = false + rule fun_NotImmutReachable_case_0{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, false) -- ImmutReachable: `%>>_%%`(fv_1, s, fv_2) + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - def $fun_NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}(fv_1, s, fv_2) = true - -- otherwise + rule fun_NotImmutReachable_case_1{fv_1 : fieldval, s : store, fv_2 : fieldval}: + `%%%%`(fv_1, s, fv_2, true) + -- ~ fun_NotImmutReachable_before_fun_NotImmutReachable_case_1: `%%%`(fv_1, s, fv_2) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation NotImmutReachable: `~%>>_%%`(fieldval, store, fieldval) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec - rule mk_NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval}: + rule mk_NotImmutReachable{fv_1 : fieldval, s : store, fv_2 : fieldval, var_0 : bool}: `~%>>_%%`(fv_1, s, fv_2) - -- if $fun_NotImmutReachable(fv_1, s, fv_2) + -- if var_0 -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Store_ok{s : store, taginst_lst : taginst*, tagtype_lst : tagtype*, globalinst_lst : globalinst*, globaltype_lst : globaltype*, meminst_lst : meminst*, memtype_lst : memtype*, tableinst_lst : tableinst*, tabletype_lst : tabletype*, deftype_lst : deftype*, funcinst_lst : funcinst*, datainst_lst : datainst*, datatype_lst : datatype*, eleminst_lst : eleminst*, elemtype_lst : elemtype*, structinst_lst : structinst*, arrayinst_lst : arrayinst*, exninst_lst : exninst*}: `|-%:OK`(s) - -- if (|taginst_lst| = |tagtype_lst|) -- (Taginst_ok: `%|-%:%`(s, v_taginst, v_tagtype))*{v_taginst <- taginst_lst, v_tagtype <- tagtype_lst} - -- if (|globalinst_lst| = |globaltype_lst|) + -- if (|taginst_lst| = |tagtype_lst|) -- (Globalinst_ok: `%|-%:%`(s, v_globalinst, v_globaltype))*{v_globalinst <- globalinst_lst, v_globaltype <- globaltype_lst} - -- if (|meminst_lst| = |memtype_lst|) + -- if (|globalinst_lst| = |globaltype_lst|) -- (Meminst_ok: `%|-%:%`(s, v_meminst, v_memtype))*{v_meminst <- meminst_lst, v_memtype <- memtype_lst} - -- if (|tableinst_lst| = |tabletype_lst|) + -- if (|meminst_lst| = |memtype_lst|) -- (Tableinst_ok: `%|-%:%`(s, v_tableinst, v_tabletype))*{v_tableinst <- tableinst_lst, v_tabletype <- tabletype_lst} - -- if (|deftype_lst| = |funcinst_lst|) + -- if (|tableinst_lst| = |tabletype_lst|) -- (Funcinst_ok: `%|-%:%`(s, v_funcinst, v_deftype))*{v_deftype <- deftype_lst, v_funcinst <- funcinst_lst} - -- if (|datainst_lst| = |datatype_lst|) + -- if (|deftype_lst| = |funcinst_lst|) -- (Datainst_ok: `%|-%:%`(s, v_datainst, v_datatype))*{v_datainst <- datainst_lst, v_datatype <- datatype_lst} - -- if (|eleminst_lst| = |elemtype_lst|) + -- if (|datainst_lst| = |datatype_lst|) -- (Eleminst_ok: `%|-%:%`(s, v_eleminst, v_elemtype))*{v_eleminst <- eleminst_lst, v_elemtype <- elemtype_lst} + -- if (|eleminst_lst| = |elemtype_lst|) -- (Structinst_ok: `%|-%:OK`(s, v_structinst))*{v_structinst <- structinst_lst} -- (Arrayinst_ok: `%|-%:OK`(s, v_arrayinst))*{v_arrayinst <- arrayinst_lst} -- (Exninst_ok: `%|-%:OK`(s, v_exninst))*{v_exninst <- exninst_lst} - -- (NotImmutReachable: `~%>>_%%`(`REF.STRUCT_ADDR`_fieldval(a), s, `REF.STRUCT_ADDR`_fieldval(a)))^(a<|structinst_lst|){} - -- (NotImmutReachable: `~%>>_%%`(`REF.ARRAY_ADDR`_fieldval(a), s, `REF.ARRAY_ADDR`_fieldval(a)))^(a<|arrayinst_lst|){} - -- (NotImmutReachable: `~%>>_%%`(`REF.EXN_ADDR`_fieldval(a), s, `REF.EXN_ADDR`_fieldval(a)))^(a<|exninst_lst|){} + -- (NotImmutReachable: `~%>>_%%`(REF_STRUCT_ADDR_fieldval(a), s, REF_STRUCT_ADDR_fieldval(a)))^(a<|structinst_lst|){} + -- (NotImmutReachable: `~%>>_%%`(REF_ARRAY_ADDR_fieldval(a), s, REF_ARRAY_ADDR_fieldval(a)))^(a<|arrayinst_lst|){} + -- (NotImmutReachable: `~%>>_%%`(REF_EXN_ADDR_fieldval(a), s, REF_EXN_ADDR_fieldval(a)))^(a<|exninst_lst|){} -- if (s = {TAGS taginst_lst, GLOBALS globalinst_lst, MEMS meminst_lst, TABLES tableinst_lst, FUNCS funcinst_lst, DATAS datainst_lst, ELEMS eleminst_lst, STRUCTS structinst_lst, ARRAYS arrayinst_lst, EXNS exninst_lst}) -- wf_store: `%`(s) -- (wf_typeuse: `%`(v_tagtype))*{v_tagtype <- tagtype_lst} @@ -16031,9 +21056,9 @@ relation Store_ok: `|-%:OK`(store) -- (wf_memtype: `%`(v_memtype))*{v_memtype <- memtype_lst} -- (wf_tabletype: `%`(v_tabletype))*{v_tabletype <- tabletype_lst} -- (wf_reftype: `%`(v_elemtype))*{v_elemtype <- elemtype_lst} - -- (wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)))^(a<|structinst_lst|){} - -- (wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)))^(a<|arrayinst_lst|){} - -- (wf_fieldval: `%`(`REF.EXN_ADDR`_fieldval(a)))^(a<|exninst_lst|){} + -- (wf_fieldval: `%`(REF_STRUCT_ADDR_fieldval(a)))^(a<|structinst_lst|){} + -- (wf_fieldval: `%`(REF_ARRAY_ADDR_fieldval(a)))^(a<|arrayinst_lst|){} + -- (wf_fieldval: `%`(REF_EXN_ADDR_fieldval(a)))^(a<|exninst_lst|){} -- wf_store: `%`({TAGS taginst_lst, GLOBALS globalinst_lst, MEMS meminst_lst, TABLES tableinst_lst, FUNCS funcinst_lst, DATAS datainst_lst, ELEMS eleminst_lst, STRUCTS structinst_lst, ARRAYS arrayinst_lst, EXNS exninst_lst}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16047,30 +21072,30 @@ relation Extend_taginst: `%<=%`(taginst, taginst) relation Extend_globalinst: `%<=%`(globalinst, globalinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_globalinst{mut_opt : mut?, t : valtype, v_val : val, val' : val}: - `%<=%`({TYPE `%%`_globaltype(mut_opt, t), VALUE v_val}, {TYPE `%%`_globaltype(mut_opt, t), VALUE val'}) + `%<=%`({TYPE mk_globaltype_globaltype(mut_opt, t), VALUE v_val}, {TYPE mk_globaltype_globaltype(mut_opt, t), VALUE val'}) -- if ((mut_opt = ?(MUT_mut)) \/ (v_val = val')) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut_opt, t), VALUE v_val}) - -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut_opt, t), VALUE val'}) + -- wf_globalinst: `%`({TYPE mk_globaltype_globaltype(mut_opt, t), VALUE v_val}) + -- wf_globalinst: `%`({TYPE mk_globaltype_globaltype(mut_opt, t), VALUE val'}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Extend_meminst: `%<=%`(meminst, meminst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_meminst{at : addrtype, v_n : n, v_m : m, b_lst : byte*, n' : n, b'_lst : byte*}: - `%<=%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))), BYTES b_lst}, {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(v_m)))), BYTES b'_lst}) + `%<=%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))), BYTES b_lst}, {TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(n'), ?(mk_uN_u64(v_m)))), BYTES b'_lst}) -- if (v_n <= n') -- if (|b_lst| <= |b'_lst|) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))), BYTES b_lst}) - -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(v_m)))), BYTES b'_lst}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))), BYTES b_lst}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, mk_limits_limits(mk_uN_u64(n'), ?(mk_uN_u64(v_m)))), BYTES b'_lst}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Extend_tableinst: `%<=%`(tableinst, tableinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_tableinst{at : addrtype, v_n : n, v_m : m, rt : reftype, ref_lst : ref*, n' : n, ref'_lst : ref*}: - `%<=%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt), REFS ref_lst}, {TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(v_m))), rt), REFS ref'_lst}) + `%<=%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt), REFS ref_lst}, {TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(n'), ?(mk_uN_u64(v_m))), rt), REFS ref'_lst}) -- if (v_n <= n') -- if (|ref_lst| <= |ref'_lst|) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))), rt), REFS ref_lst}) - -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(`%`_u64(n'), ?(`%`_u64(v_m))), rt), REFS ref'_lst}) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))), rt), REFS ref_lst}) + -- wf_tableinst: `%`({TYPE mk_tabletype_tabletype(at, mk_limits_limits(mk_uN_u64(n'), ?(mk_uN_u64(v_m))), rt), REFS ref'_lst}) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Extend_funcinst: `%<=%`(funcinst, funcinst) @@ -16102,25 +21127,25 @@ relation Extend_structinst: `%<=%`(structinst, structinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_structinst{dt : deftype, fv_lst : fieldval*, fv'_lst : fieldval*, mut_opt_lst : mut?*, zt_lst : storagetype*}: `%<=%`({TYPE dt, FIELDS fv_lst}, {TYPE dt, FIELDS fv'_lst}) - -- Expand: `%~~%`(dt, STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- Expand: `%~~%`(dt, STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- (if ((mut_opt = ?(MUT_mut)) \/ (fv = fv')))*{fv <- fv_lst, fv' <- fv'_lst, mut_opt <- mut_opt_lst} -- if (|fv_lst| = |fv'_lst|) -- if (|fv_lst| = |mut_opt_lst|) - -- (if ((mut_opt = ?(MUT_mut)) \/ (fv = fv')))*{fv <- fv_lst, fv' <- fv'_lst, mut_opt <- mut_opt_lst} -- wf_structinst: `%`({TYPE dt, FIELDS fv_lst}) -- wf_structinst: `%`({TYPE dt, FIELDS fv'_lst}) - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- wf_comptype: `%`(STRUCT_comptype(mk_list_list(mk_fieldtype_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_arrayinst{dt : deftype, fv_lst : fieldval*, fv'_lst : fieldval*, mut_opt : mut?, zt : storagetype}: `%<=%`({TYPE dt, FIELDS fv_lst}, {TYPE dt, FIELDS fv'_lst}) - -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if (|fv_lst| = |fv'_lst|) + -- Expand: `%~~%`(dt, ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) -- (if ((mut_opt = ?(MUT_mut)) \/ (fv = fv')))*{fv <- fv_lst, fv' <- fv'_lst} + -- if (|fv_lst| = |fv'_lst|) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv_lst}) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'_lst}) - -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- wf_comptype: `%`(ARRAY_comptype(mk_fieldtype_fieldtype(mut_opt, zt))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Extend_exninst: `%<=%`(exninst, exninst) @@ -16134,36 +21159,36 @@ relation Extend_store: `%<=%`(store, store) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Extend_store{s : store, s' : store}: `%<=%`(s, s') + -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} -- (if (a < |s.TAGS_store|))^(a<|s.TAGS_store|){} -- (if (a < |s'.TAGS_store|))^(a<|s.TAGS_store|){} - -- (Extend_taginst: `%<=%`(s.TAGS_store[a], s'.TAGS_store[a]))^(a<|s.TAGS_store|){} + -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} -- (if (a < |s.GLOBALS_store|))^(a<|s.GLOBALS_store|){} -- (if (a < |s'.GLOBALS_store|))^(a<|s.GLOBALS_store|){} - -- (Extend_globalinst: `%<=%`(s.GLOBALS_store[a], s'.GLOBALS_store[a]))^(a<|s.GLOBALS_store|){} + -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} -- (if (a < |s.MEMS_store|))^(a<|s.MEMS_store|){} -- (if (a < |s'.MEMS_store|))^(a<|s.MEMS_store|){} - -- (Extend_meminst: `%<=%`(s.MEMS_store[a], s'.MEMS_store[a]))^(a<|s.MEMS_store|){} + -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} -- (if (a < |s.TABLES_store|))^(a<|s.TABLES_store|){} -- (if (a < |s'.TABLES_store|))^(a<|s.TABLES_store|){} - -- (Extend_tableinst: `%<=%`(s.TABLES_store[a], s'.TABLES_store[a]))^(a<|s.TABLES_store|){} + -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} -- (if (a < |s.FUNCS_store|))^(a<|s.FUNCS_store|){} -- (if (a < |s'.FUNCS_store|))^(a<|s.FUNCS_store|){} - -- (Extend_funcinst: `%<=%`(s.FUNCS_store[a], s'.FUNCS_store[a]))^(a<|s.FUNCS_store|){} + -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} -- (if (a < |s.DATAS_store|))^(a<|s.DATAS_store|){} -- (if (a < |s'.DATAS_store|))^(a<|s.DATAS_store|){} - -- (Extend_datainst: `%<=%`(s.DATAS_store[a], s'.DATAS_store[a]))^(a<|s.DATAS_store|){} + -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} -- (if (a < |s.ELEMS_store|))^(a<|s.ELEMS_store|){} -- (if (a < |s'.ELEMS_store|))^(a<|s.ELEMS_store|){} - -- (Extend_eleminst: `%<=%`(s.ELEMS_store[a], s'.ELEMS_store[a]))^(a<|s.ELEMS_store|){} + -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} -- (if (a < |s.STRUCTS_store|))^(a<|s.STRUCTS_store|){} -- (if (a < |s'.STRUCTS_store|))^(a<|s.STRUCTS_store|){} - -- (Extend_structinst: `%<=%`(s.STRUCTS_store[a], s'.STRUCTS_store[a]))^(a<|s.STRUCTS_store|){} + -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} -- (if (a < |s.ARRAYS_store|))^(a<|s.ARRAYS_store|){} -- (if (a < |s'.ARRAYS_store|))^(a<|s.ARRAYS_store|){} - -- (Extend_arrayinst: `%<=%`(s.ARRAYS_store[a], s'.ARRAYS_store[a]))^(a<|s.ARRAYS_store|){} + -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- (if (a < |s.EXNS_store|))^(a<|s.EXNS_store|){} -- (if (a < |s'.EXNS_store|))^(a<|s.EXNS_store|){} - -- (Extend_exninst: `%<=%`(s.EXNS_store[a], s'.EXNS_store[a]))^(a<|s.EXNS_store|){} -- wf_store: `%`(s) -- wf_store: `%`(s') @@ -16171,23 +21196,23 @@ relation Extend_store: `%<=%`(store, store) relation State_ok: `|-%:%`(state, context) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_State_ok{s : store, f : frame, C : context}: - `|-%:%`(`%;%`_state(s, f), C) + `|-%:%`(mk_state_state(s, f), C) -- Store_ok: `|-%:OK`(s) -- Frame_ok: `%|-%:%`(s, f, C) -- wf_context: `%`(C) - -- wf_state: `%`(`%;%`_state(s, f)) + -- wf_state: `%`(mk_state_state(s, f)) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Config_ok: `|-%:%`(config, resulttype) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec rule mk_Config_ok{s : store, f : frame, instr_lst : instr*, t_lst : valtype*, C : context}: - `|-%:%`(`%;%`_config(`%;%`_state(s, f), instr_lst), `%`_resulttype(t_lst)) - -- State_ok: `|-%:%`(`%;%`_state(s, f), C) - -- Expr_ok2: `%;%|-%:%`(s, C, instr_lst, `%`_resulttype(t_lst)) + `|-%:%`(mk_config_config(mk_state_state(s, f), instr_lst), mk_list_resulttype(t_lst)) + -- State_ok: `|-%:%`(mk_state_state(s, f), C) + -- Expr_ok2: `%;%|-%:%`(s, C, instr_lst, mk_list_resulttype(t_lst)) -- (wf_valtype: `%`(t))*{t <- t_lst} -- wf_context: `%`(C) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), instr_lst)) - -- wf_state: `%`(`%;%`_state(s, f)) + -- wf_config: `%`(mk_config_config(mk_state_state(s, f), instr_lst)) + -- wf_state: `%`(mk_state_state(s, f)) ;; ../../../../specification/wasm-3.0/X.1-notation.syntax.spectec syntax A = nat @@ -16247,30 +21272,30 @@ rec { relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:22.1-23.38 rule i32_add{C : context}: - `%|-%:%`(C, [BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn))], `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([I32_valtype]))) + `%|-%:%`(C, [BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn))], mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([I32_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(BINOP_instr(I32_numtype, mk_binop__0_binop_(I32_Inn, ADD_binop_Inn))) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([I32_valtype]))) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([I32_valtype I32_valtype]), [], mk_list_resulttype([I32_valtype]))) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:25.1-27.29 rule global_get{C : context, x : idx, t : valtype, v_mut : mut}: - `%|-%:%`(C, [`GLOBAL.GET`_instr(x)], `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + `%|-%:%`(C, [GLOBAL_GET_instr(x)], mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = mk_globaltype_globaltype(?(v_mut), t)) -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) - -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(v_mut), t)) -- wf_context: `%`(C) - -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) - -- wf_globaltype: `%`(`%%`_globaltype(?(v_mut), t)) + -- wf_instr: `%`(GLOBAL_GET_instr(x)) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype([]), [], mk_list_resulttype([t]))) + -- wf_globaltype: `%`(mk_globaltype_globaltype(?(v_mut), t)) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:29.1-32.78 rule block{C : context, v_blocktype : blocktype, instr_lst : instr*, t_1_lst : valtype*, t_2_lst : valtype*}: - `%|-%:%`(C, [BLOCK_instr(v_blocktype, instr_lst)], `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- Blocktype_ok: `%|-%:%`(C, v_blocktype, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- NotationTypingInstrScheme: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + `%|-%:%`(C, [BLOCK_instr(v_blocktype, instr_lst)], mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- Blocktype_ok: `%|-%:%`(C, v_blocktype, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- NotationTypingInstrScheme: `%|-%:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []} +++ C, instr_lst, mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(BLOCK_instr(v_blocktype, instr_lst)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) - -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [`%`_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) + -- wf_instrtype: `%`(mk_instrtype_instrtype(mk_list_resulttype(t_1_lst), [], mk_list_resulttype(t_2_lst))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [mk_list_resulttype(t_2_lst)], RETURN ?(), REFS [], RECS []}) } ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec @@ -16299,6 +21324,14 @@ relation NotationReduct: `~>%`(instr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec def $instrdots : instr* +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation instrdots_is_wf: `%`(ret_val : instr*) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule instrdots_is_wf_0{ret_val : instr*}: + `%`(ret_val) + -- if (ret_val = $instrdots) + -- (wf_instr: `%`(ret_val))*{ret_val <- ret_val} + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec syntax label = | `LABEL_%{%}`(v_n : n, instr_lst : instr*) @@ -16322,36 +21355,58 @@ relation wf_callframe: `%`(callframe) -- wf_frame: `%`(v_frame) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec -def $allocX(syntax X, syntax Y, v_store : store, X_0 : X, Y_0 : Y) : (store, addr) +def $allocX(syntax r_X, syntax Y, v_store : store, v_X : r_X, Y_0 : Y) : (store, addr) + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +relation allocX_is_wf(syntax r_X, syntax Y): `%%%%`(v_store : store, X_0 : r_X, Y_0 : Y, ret_val : (store, addr)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec + rule allocX_is_wf_0{syntax r_X, syntax Y, v_store : store, X_0 : r_X, Y_0 : Y, ret_val : (store, addr)}: + `%%%%`(v_store, X_0, Y_0, ret_val) + -- wf_store: `%`(v_store) + -- if (ret_val = $allocX(syntax r_X, syntax Y, v_store, X_0, Y_0)) + -- wf_store: `%`(ret_val.0) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec rec { ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.1-32.117 -def $allocXs(syntax X, syntax Y, v_store : store, var_0 : X*, var_1 : Y*) : (store, addr*) +def $allocXs(syntax r_X, syntax Y, v_store : store, var_0 : r_X*, var_1 : Y*) : (store, addr*) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:33.1-33.57 - def $allocXs{syntax X, syntax Y, s : store}(syntax X, syntax Y, s, [], []) = (s, []) + def $allocXs{syntax r_X, syntax Y, s : store}(syntax r_X, syntax Y, s, [], []) = (s, []) ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:34.1-36.65 - def $allocXs{syntax X, syntax Y, s : store, X : X, X'_lst : X*, Y : Y, Y'_lst : Y*}(syntax X, syntax Y, s, [X] ++ X'_lst, [Y] ++ Y'_lst) = (s_2, [a] ++ a'_lst) - -- let{a : addr, s_1 : store} (s_1, a) = $allocX(syntax X, syntax Y, s, X, Y) - -- let{s_2 : store, a'_lst : addr*} (s_2, a'_lst) = $allocXs(syntax X, syntax Y, s_1, X'_lst, Y'_lst) + def $allocXs{syntax r_X, syntax Y, s : store, v_X : r_X, X'_lst : r_X*, Y : Y, Y'_lst : Y*}(syntax r_X, syntax Y, s, [v_X] ++ X'_lst, [Y] ++ Y'_lst) = (s_2, [a] ++ a'_lst) + -- let{a : addr, s_1 : store} (s_1, a) = $allocX(syntax r_X, syntax Y, s, v_X, Y) + -- let{s_2 : store, a'_lst : addr*} (s_2, a'_lst) = $allocXs(syntax r_X, syntax Y, s_1, X'_lst, Y'_lst) +} + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec +rec { + +;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 +relation allocXs_is_wf(syntax r_X, syntax Y): `%%%%`(v_store : store, var_0 : r_X*, var_1 : Y*, ret_val : (store, addr*)) + ;; ../../../../specification/wasm-3.0/X.3-notation.execution.spectec:32.6-32.14 + rule allocXs_is_wf_0{syntax r_X, syntax Y, v_store : store, var_0 : r_X*, var_1 : Y*, ret_val : (store, addr*)}: + `%%%%`(v_store, var_0, var_1, ret_val) + -- wf_store: `%`(v_store) + -- if (ret_val = $allocXs(syntax r_X, syntax Y, v_store, var_0, var_1)) + -- wf_store: `%`(ret_val.0) } ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec syntax symdots = - | `%`(i : nat) + | mk_symdots(i : nat) ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec relation wf_symdots: `%`(symdots) ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec rule symdots_case_0{i : nat}: - `%`(`%`_symdots(i)) + `%`(mk_symdots_symdots(i)) -- if (i = 0) ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -def $var(syntax X) : nat +def $var(syntax r_X) : nat ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec - def $var{syntax X}(syntax X) = 0 + def $var{syntax r_X}(syntax r_X) = 0 ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec syntax abbreviated = () @@ -16365,7 +21420,7 @@ syntax syntax = () ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Bbyte : byte ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{`` : nat} ``:(0x00 | ... | 0xFF) => `%`_byte(``) + prod{`` : nat} ``:(0x00 | ... | 0xFF) => mk_byte_byte(``) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec rec { @@ -16373,10 +21428,10 @@ rec { ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:9.1-11.82 grammar BuN(v_N : N) : uN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:10.5-10.83 - prod{v_n : n} `%`_byte(v_n):Bbyte => `%`_uN(v_n) + prod{v_n : n} mk_byte_byte(v_n):Bbyte => mk_uN_uN(v_n) -- if ((v_n < (2 ^ 7)) /\ (v_n < (2 ^ v_N))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:11.5-11.82 - prod{v_m : m, v_n : n} {{`%`_byte(v_n):Bbyte} {`%`_uN(v_m):BuN((((v_N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_uN((((2 ^ 7) * v_m) + (((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat))) + prod{v_m : m, v_n : n} {{mk_byte_byte(v_n):Bbyte} {mk_uN_uN(v_m):BuN((((v_N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => mk_uN_uN((((2 ^ 7) * v_m) + (((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat))) -- if ((v_n >= (2 ^ 7)) /\ (v_N > 7)) } @@ -16386,20 +21441,21 @@ rec { ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:13.1-16.82 grammar BsN(v_N : N) : sN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:14.5-14.87 - prod{v_n : n} `%`_byte(v_n):Bbyte => `%`_sN((v_n : nat <:> int)) + prod{v_n : n} mk_byte_byte(v_n):Bbyte => mk_sN_sN((v_n : nat <:> int)) -- if ((v_n < (2 ^ 6)) /\ (v_n < (2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:15.5-15.101 - prod{v_n : n} `%`_byte(v_n):Bbyte => `%`_sN(((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int))) + prod{v_n : n} mk_byte_byte(v_n):Bbyte => mk_sN_sN(((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int))) -- if ((((2 ^ 6) <= v_n) /\ (v_n < (2 ^ 7))) /\ ((v_n : nat <:> int) >= (((2 ^ 7) : nat <:> int) - ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)))) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec:16.5-16.82 - prod{i : sN, v_n : n} {{`%`_byte(v_n):Bbyte} {i:BsN((((v_N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => `%`_sN(((((2 ^ 7) * ($proj_sN_0(i).0 : int <:> nat)) + (((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat)) : nat <:> int)) + prod{i : sN, v_n : n} {{mk_byte_byte(v_n):Bbyte} {i:BsN((((v_N : nat <:> int) - (7 : nat <:> int)) : int <:> nat))}} => mk_sN_sN(((((2 ^ 7) * ($proj_sN_0(i).0 : int <:> nat)) + (((v_n : nat <:> int) - ((2 ^ 7) : nat <:> int)) : int <:> nat)) : nat <:> int)) -- if ((v_n >= (2 ^ 7)) /\ (v_N > 7)) } ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BiN(v_N : N) : iN ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{i : sN} i:BsN(v_N) => `%`_iN($inv_signed_(v_N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:BsN(v_N) => mk_uN_iN(var_0) + -- fun_inv_signed_: `%%%`(v_N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar BfN(v_N : N) : fN @@ -16444,13 +21500,14 @@ grammar Bf64 : f64 ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Blist(syntax el, grammar BX : el) : el* ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{v_n : n, el_lst : el*} {{`%`_u32(v_n):Bu32} {el:BX^v_n{el <- el_lst}}} => el_lst + prod{v_n : n, el_lst : el*} {{mk_uN_u32(v_n):Bu32} {el:BX^v_n{el <- el_lst}}} => el_lst ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Bname : name ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec - prod{v_name : name, b_lst : byte*} b_lst:Blist(syntax byte, grammar Bbyte) => v_name - -- if ($utf8($proj_name_0(v_name).0) = b_lst) + prod{v_name : name, b_lst : byte*, var_0 : byte*} b_lst:Blist(syntax byte, grammar Bbyte) => v_name + -- if (var_0 = b_lst) + -- fun_utf8: `%%`($proj_name_0(v_name).0, var_0) ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec grammar Btypeidx : typeidx @@ -16592,7 +21649,7 @@ grammar Bvaltype : valtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bresulttype : resulttype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{t_lst : valtype*} t_lst:Blist(syntax valtype, grammar Bvaltype) => `%`_resulttype(t_lst) + prod{t_lst : valtype*} t_lst:Blist(syntax valtype, grammar Bvaltype) => mk_list_resulttype(t_lst) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bmut : mut? @@ -16618,16 +21675,16 @@ grammar Bstoragetype : storagetype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bfieldtype : fieldtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{mut_opt : mut?, zt : storagetype} {{zt:Bstoragetype} {mut_opt:Bmut}} => `%%`_fieldtype(mut_opt, zt) + prod{mut_opt : mut?, zt : storagetype} {{zt:Bstoragetype} {mut_opt:Bmut}} => mk_fieldtype_fieldtype(mut_opt, zt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bcomptype : comptype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec prod{ft : fieldtype} {{0x5E} {ft:Bfieldtype}} => ARRAY_comptype(ft) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{ft_lst : fieldtype*} {{0x5F} {ft_lst:Blist(syntax fieldtype, grammar Bfieldtype)}} => STRUCT_comptype(`%`_list(ft_lst)) + prod{ft_lst : fieldtype*} {{0x5F} {ft_lst:Blist(syntax fieldtype, grammar Bfieldtype)}} => STRUCT_comptype(mk_list_list(ft_lst)) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{t_1_lst : valtype*, t_2_lst : valtype*} {{0x60} {`%`_resulttype(t_1_lst):Bresulttype} {`%`_resulttype(t_2_lst):Bresulttype}} => `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)) + prod{t_1_lst : valtype*, t_2_lst : valtype*} {{0x60} {mk_list_resulttype(t_1_lst):Bresulttype} {mk_list_resulttype(t_2_lst):Bresulttype}} => `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bsubtype : subtype @@ -16641,20 +21698,20 @@ grammar Bsubtype : subtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Brectype : rectype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{st_lst : subtype*} {{0x4E} {st_lst:Blist(syntax subtype, grammar Bsubtype)}} => REC_rectype(`%`_list(st_lst)) + prod{st_lst : subtype*} {{0x4E} {st_lst:Blist(syntax subtype, grammar Bsubtype)}} => REC_rectype(mk_list_list(st_lst)) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{st : subtype} st:Bsubtype => REC_rectype(`%`_list([st])) + prod{st : subtype} st:Bsubtype => REC_rectype(mk_list_list([st])) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Blimits : (addrtype, limits) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{v_n : n} {{0x00} {`%`_u64(v_n):Bu64}} => (I32_addrtype, `[%..%]`_limits(`%`_u64(v_n), ?())) + prod{v_n : n} {{0x00} {mk_uN_u64(v_n):Bu64}} => (I32_addrtype, mk_limits_limits(mk_uN_u64(v_n), ?())) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{v_n : n, v_m : m} {{0x01} {`%`_u64(v_n):Bu64} {`%`_u64(v_m):Bu64}} => (I32_addrtype, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))) + prod{v_n : n, v_m : m} {{0x01} {mk_uN_u64(v_n):Bu64} {mk_uN_u64(v_m):Bu64}} => (I32_addrtype, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{v_n : n} {{0x04} {`%`_u64(v_n):Bu64}} => (I64_addrtype, `[%..%]`_limits(`%`_u64(v_n), ?())) + prod{v_n : n} {{0x04} {mk_uN_u64(v_n):Bu64}} => (I64_addrtype, mk_limits_limits(mk_uN_u64(v_n), ?())) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{v_n : n, v_m : m} {{0x05} {`%`_u64(v_n):Bu64} {`%`_u64(v_m):Bu64}} => (I64_addrtype, `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m)))) + prod{v_n : n, v_m : m} {{0x05} {mk_uN_u64(v_n):Bu64} {mk_uN_u64(v_m):Bu64}} => (I64_addrtype, mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m)))) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Btagtype : tagtype @@ -16664,7 +21721,7 @@ grammar Btagtype : tagtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bglobaltype : globaltype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{mut_opt : mut?, t : valtype} {{t:Bvaltype} {mut_opt:Bmut}} => `%%`_globaltype(mut_opt, t) + prod{mut_opt : mut?, t : valtype} {{t:Bvaltype} {mut_opt:Bmut}} => mk_globaltype_globaltype(mut_opt, t) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bmemtype : memtype @@ -16674,7 +21731,7 @@ grammar Bmemtype : memtype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Btabletype : tabletype ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec - prod{at : addrtype, lim : limits, rt : reftype} {{rt:Breftype} {(at, lim):Blimits}} => `%%%`_tabletype(at, lim, rt) + prod{at : addrtype, lim : limits, rt : reftype} {{rt:Breftype} {(at, lim):Blimits}} => mk_tabletype_tabletype(at, lim, rt) ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec grammar Bexterntype : externtype @@ -16707,7 +21764,7 @@ grammar Bblocktype : blocktype ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec prod{t : valtype} t:Bvaltype => _RESULT_blocktype(?(t)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{i : s33} i:Bs33 => _IDX_blocktype(`%`_typeidx(($proj_sN_0(i).0 : int <:> nat))) + prod{i : s33} i:Bs33 => _IDX_blocktype(mk_uN_typeidx(($proj_sN_0(i).0 : int <:> nat))) -- if ($proj_sN_0(i).0 >= (0 : nat <:> int)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec @@ -16724,16 +21781,16 @@ grammar Bcatch : catch ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec grammar Bmemarg : memidxop ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{v_n : n, v_m : m} {{`%`_u32(v_n):Bu32} {`%`_u64(v_m):Bu64}} => (`%`_memidx(0), {ALIGN `%`_u32(v_n), OFFSET `%`_u64(v_m)}) + prod{v_n : n, v_m : m} {{mk_uN_u32(v_n):Bu32} {mk_uN_u64(v_m):Bu64}} => (mk_uN_memidx(0), {ALIGN mk_uN_u32(v_n), OFFSET mk_uN_u64(v_m)}) -- if (v_n < (2 ^ 6)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{x : idx, v_n : n, v_m : m} {{`%`_u32(v_n):Bu32} {x:Bmemidx} {`%`_u64(v_m):Bu64}} => (x, {ALIGN `%`_u32((((v_n : nat <:> int) - ((2 ^ 6) : nat <:> int)) : int <:> nat)), OFFSET `%`_u64(v_m)}) + prod{x : idx, v_n : n, v_m : m} {{mk_uN_u32(v_n):Bu32} {x:Bmemidx} {mk_uN_u64(v_m):Bu64}} => (x, {ALIGN mk_uN_u32((((v_n : nat <:> int) - ((2 ^ 6) : nat <:> int)) : int <:> nat)), OFFSET mk_uN_u64(v_m)}) -- if (((2 ^ 6) <= v_n) /\ (v_n < (2 ^ 7))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec grammar Blaneidx : laneidx ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec - prod{l : labelidx} `%`_byte($proj_uN_0(l).0):Bbyte => `%`_laneidx($proj_uN_0(l).0) + prod{l : labelidx} mk_byte_byte($proj_uN_0(l).0):Bbyte => mk_uN_laneidx($proj_uN_0(l).0) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec rec { @@ -16783,41 +21840,41 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:51.5-51.48 prod{x : idx} {{0x15} {x:Btypeidx}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:52.5-52.81 - prod{bt : blocktype, c_lst : catch*, in_lst : instr*} {{0x1F} {bt:Bblocktype} {c_lst:Blist(syntax catch, grammar Bcatch)} {in:Binstr*{in <- in_lst}} {0x0B}} => TRY_TABLE_instr(bt, `%`_list(c_lst), in_lst) + prod{bt : blocktype, c_lst : catch*, in_lst : instr*} {{0x1F} {bt:Bblocktype} {c_lst:Blist(syntax catch, grammar Bcatch)} {in:Binstr*{in <- in_lst}} {0x0B}} => TRY_TABLE_instr(bt, mk_list_list(c_lst), in_lst) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:53.5-53.37 prod{l : labelidx} {{0xD5} {l:Blabelidx}} => BR_ON_NULL_instr(l) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:54.5-54.41 prod{l : labelidx} {{0xD6} {l:Blabelidx}} => BR_ON_NON_NULL_instr(l) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:55.5-56.100 - prod{l : labelidx, null_1_opt : null?, ht_1 : heaptype, null_2_opt : null?, ht_2 : heaptype} {{0xFB} {`%`_u32(24):Bu32} {(null_1_opt, null_2_opt):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_instr(l, REF_reftype(null_1_opt, ht_1), REF_reftype(null_2_opt, ht_2)) + prod{l : labelidx, null_1_opt : null?, ht_1 : heaptype, null_2_opt : null?, ht_2 : heaptype} {{0xFB} {mk_uN_u32(24):Bu32} {(null_1_opt, null_2_opt):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_instr(l, REF_reftype(null_1_opt, ht_1), REF_reftype(null_2_opt, ht_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:57.5-58.105 - prod{l : labelidx, null_1_opt : null?, ht_1 : heaptype, null_2_opt : null?, ht_2 : heaptype} {{0xFB} {`%`_u32(25):Bu32} {(null_1_opt, null_2_opt):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_FAIL_instr(l, REF_reftype(null_1_opt, ht_1), REF_reftype(null_2_opt, ht_2)) + prod{l : labelidx, null_1_opt : null?, ht_1 : heaptype, null_2_opt : null?, ht_2 : heaptype} {{0xFB} {mk_uN_u32(25):Bu32} {(null_1_opt, null_2_opt):Bcastop} {l:Blabelidx} {ht_1:Bheaptype} {ht_2:Bheaptype}} => BR_ON_CAST_FAIL_instr(l, REF_reftype(null_1_opt, ht_1), REF_reftype(null_2_opt, ht_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:71.5-71.36 - prod{x : idx} {{0x20} {x:Blocalidx}} => `LOCAL.GET`_instr(x) + prod{x : idx} {{0x20} {x:Blocalidx}} => LOCAL_GET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:72.5-72.36 - prod{x : idx} {{0x21} {x:Blocalidx}} => `LOCAL.SET`_instr(x) + prod{x : idx} {{0x21} {x:Blocalidx}} => LOCAL_SET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:73.5-73.36 - prod{x : idx} {{0x22} {x:Blocalidx}} => `LOCAL.TEE`_instr(x) + prod{x : idx} {{0x22} {x:Blocalidx}} => LOCAL_TEE_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:77.5-77.38 - prod{x : idx} {{0x23} {x:Bglobalidx}} => `GLOBAL.GET`_instr(x) + prod{x : idx} {{0x23} {x:Bglobalidx}} => GLOBAL_GET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:78.5-78.38 - prod{x : idx} {{0x24} {x:Bglobalidx}} => `GLOBAL.SET`_instr(x) + prod{x : idx} {{0x24} {x:Bglobalidx}} => GLOBAL_SET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:85.5-85.36 - prod{x : idx} {{0x25} {x:Btableidx}} => `TABLE.GET`_instr(x) + prod{x : idx} {{0x25} {x:Btableidx}} => TABLE_GET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:86.5-86.36 - prod{x : idx} {{0x26} {x:Btableidx}} => `TABLE.SET`_instr(x) + prod{x : idx} {{0x26} {x:Btableidx}} => TABLE_SET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:87.5-87.58 - prod{x : idx, y : idx} {{0xFC} {`%`_u32(12):Bu32} {y:Belemidx} {x:Btableidx}} => `TABLE.INIT`_instr(x, y) + prod{x : idx, y : idx} {{0xFC} {mk_uN_u32(12):Bu32} {y:Belemidx} {x:Btableidx}} => TABLE_INIT_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:88.5-88.43 - prod{x : idx} {{0xFC} {`%`_u32(13):Bu32} {x:Belemidx}} => `ELEM.DROP`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(13):Bu32} {x:Belemidx}} => ELEM_DROP_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:89.5-89.67 - prod{x_1 : idx, x_2 : idx} {{0xFC} {`%`_u32(14):Bu32} {x_1:Btableidx} {x_2:Btableidx}} => `TABLE.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{0xFC} {mk_uN_u32(14):Bu32} {x_1:Btableidx} {x_2:Btableidx}} => TABLE_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:90.5-90.45 - prod{x : idx} {{0xFC} {`%`_u32(15):Bu32} {x:Btableidx}} => `TABLE.GROW`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(15):Bu32} {x:Btableidx}} => TABLE_GROW_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:91.5-91.45 - prod{x : idx} {{0xFC} {`%`_u32(16):Bu32} {x:Btableidx}} => `TABLE.SIZE`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(16):Bu32} {x:Btableidx}} => TABLE_SIZE_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:92.5-92.45 - prod{x : idx} {{0xFC} {`%`_u32(17):Bu32} {x:Btableidx}} => `TABLE.FILL`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(17):Bu32} {x:Btableidx}} => TABLE_FILL_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:105.5-105.41 prod{x : idx, ao : memarg} {{0x28} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:106.5-106.41 @@ -16827,25 +21884,25 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:108.5-108.41 prod{x : idx, ao : memarg} {{0x2B} {(x, ao):Bmemarg}} => LOAD_instr(F64_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:109.5-109.50 - prod{x : idx, ao : memarg} {{0x2C} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x2C} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:110.5-110.50 - prod{x : idx, ao : memarg} {{0x2D} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x2D} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:111.5-111.51 - prod{x : idx, ao : memarg} {{0x2E} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x2E} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:112.5-112.51 - prod{x : idx, ao : memarg} {{0x2F} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x2F} {(x, ao):Bmemarg}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:113.5-113.50 - prod{x : idx, ao : memarg} {{0x30} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x30} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:114.5-114.50 - prod{x : idx, ao : memarg} {{0x31} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x31} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:115.5-115.51 - prod{x : idx, ao : memarg} {{0x32} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x32} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:116.5-116.51 - prod{x : idx, ao : memarg} {{0x33} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x33} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:117.5-117.51 - prod{x : idx, ao : memarg} {{0x34} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x34} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(32), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:118.5-118.51 - prod{x : idx, ao : memarg} {{0x35} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{0x35} {(x, ao):Bmemarg}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(32), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:119.5-119.42 prod{x : idx, ao : memarg} {{0x36} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:120.5-120.42 @@ -16855,95 +21912,95 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:122.5-122.42 prod{x : idx, ao : memarg} {{0x39} {(x, ao):Bmemarg}} => STORE_instr(F64_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:123.5-123.45 - prod{x : idx, ao : memarg} {{0x3A} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) + prod{x : idx, ao : memarg} {{0x3A} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:124.5-124.46 - prod{x : idx, ao : memarg} {{0x3B} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) + prod{x : idx, ao : memarg} {{0x3B} {(x, ao):Bmemarg}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(16)))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:125.5-125.45 - prod{x : idx, ao : memarg} {{0x3C} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) + prod{x : idx, ao : memarg} {{0x3C} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:126.5-126.46 - prod{x : idx, ao : memarg} {{0x3D} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) + prod{x : idx, ao : memarg} {{0x3D} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(16)))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:127.5-127.46 - prod{x : idx, ao : memarg} {{0x3E} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(32)))), x, ao) + prod{x : idx, ao : memarg} {{0x3E} {(x, ao):Bmemarg}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(32)))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:128.5-128.36 - prod{x : idx} {{0x3F} {x:Bmemidx}} => `MEMORY.SIZE`_instr(x) + prod{x : idx} {{0x3F} {x:Bmemidx}} => MEMORY_SIZE_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:129.5-129.36 - prod{x : idx} {{0x40} {x:Bmemidx}} => `MEMORY.GROW`_instr(x) + prod{x : idx} {{0x40} {x:Bmemidx}} => MEMORY_GROW_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:130.5-130.56 - prod{x : idx, y : idx} {{0xFC} {`%`_u32(8):Bu32} {y:Bdataidx} {x:Bmemidx}} => `MEMORY.INIT`_instr(x, y) + prod{x : idx, y : idx} {{0xFC} {mk_uN_u32(8):Bu32} {y:Bdataidx} {x:Bmemidx}} => MEMORY_INIT_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:131.5-131.42 - prod{x : idx} {{0xFC} {`%`_u32(9):Bu32} {x:Bdataidx}} => `DATA.DROP`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(9):Bu32} {x:Bdataidx}} => DATA_DROP_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:132.5-132.64 - prod{x_1 : idx, x_2 : idx} {{0xFC} {`%`_u32(10):Bu32} {x_1:Bmemidx} {x_2:Bmemidx}} => `MEMORY.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{0xFC} {mk_uN_u32(10):Bu32} {x_1:Bmemidx} {x_2:Bmemidx}} => MEMORY_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:133.5-133.44 - prod{x : idx} {{0xFC} {`%`_u32(11):Bu32} {x:Bmemidx}} => `MEMORY.FILL`_instr(x) + prod{x : idx} {{0xFC} {mk_uN_u32(11):Bu32} {x:Bmemidx}} => MEMORY_FILL_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:140.5-140.37 - prod{ht : heaptype} {{0xD0} {ht:Bheaptype}} => `REF.NULL`_instr(ht) + prod{ht : heaptype} {{0xD0} {ht:Bheaptype}} => REF_NULL_instr(ht) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:141.5-141.24 - prod 0xD1 => `REF.IS_NULL`_instr + prod 0xD1 => REF_IS_NULL_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:142.5-142.34 - prod{x : idx} {{0xD2} {x:Bfuncidx}} => `REF.FUNC`_instr(x) + prod{x : idx} {{0xD2} {x:Bfuncidx}} => REF_FUNC_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:143.5-143.19 - prod 0xD3 => `REF.EQ`_instr + prod 0xD3 => REF_EQ_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:144.5-144.28 - prod 0xD4 => `REF.AS_NON_NULL`_instr + prod 0xD4 => REF_AS_NON_NULL_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:145.5-145.51 - prod{ht : heaptype} {{0xFB} {`%`_u32(20):Bu32} {ht:Bheaptype}} => `REF.TEST`_instr(REF_reftype(?(), ht)) + prod{ht : heaptype} {{0xFB} {mk_uN_u32(20):Bu32} {ht:Bheaptype}} => REF_TEST_instr(REF_reftype(?(), ht)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:146.5-146.56 - prod{ht : heaptype} {{0xFB} {`%`_u32(21):Bu32} {ht:Bheaptype}} => `REF.TEST`_instr(REF_reftype(?(NULL_null), ht)) + prod{ht : heaptype} {{0xFB} {mk_uN_u32(21):Bu32} {ht:Bheaptype}} => REF_TEST_instr(REF_reftype(?(NULL_null), ht)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:147.5-147.51 - prod{ht : heaptype} {{0xFB} {`%`_u32(22):Bu32} {ht:Bheaptype}} => `REF.CAST`_instr(REF_reftype(?(), ht)) + prod{ht : heaptype} {{0xFB} {mk_uN_u32(22):Bu32} {ht:Bheaptype}} => REF_CAST_instr(REF_reftype(?(), ht)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:148.5-148.56 - prod{ht : heaptype} {{0xFB} {`%`_u32(23):Bu32} {ht:Bheaptype}} => `REF.CAST`_instr(REF_reftype(?(NULL_null), ht)) + prod{ht : heaptype} {{0xFB} {mk_uN_u32(23):Bu32} {ht:Bheaptype}} => REF_CAST_instr(REF_reftype(?(NULL_null), ht)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:152.5-152.43 - prod{x : idx} {{0xFB} {`%`_u32(0):Bu32} {x:Btypeidx}} => `STRUCT.NEW`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(0):Bu32} {x:Btypeidx}} => STRUCT_NEW_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:153.5-153.51 - prod{x : idx} {{0xFB} {`%`_u32(1):Bu32} {x:Btypeidx}} => `STRUCT.NEW_DEFAULT`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(1):Bu32} {x:Btypeidx}} => STRUCT_NEW_DEFAULT_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:154.5-154.57 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(2):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(), x, i) + prod{x : idx, i : fieldidx} {{0xFB} {mk_uN_u32(2):Bu32} {x:Btypeidx} {i:Bfieldidx}} => STRUCT_GET_instr(?(), x, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:155.5-155.59 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(3):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(S_sx), x, i) + prod{x : idx, i : fieldidx} {{0xFB} {mk_uN_u32(3):Bu32} {x:Btypeidx} {i:Bfieldidx}} => STRUCT_GET_instr(?(S_sx), x, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:156.5-156.59 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(4):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.GET`_instr(?(U_sx), x, i) + prod{x : idx, i : fieldidx} {{0xFB} {mk_uN_u32(4):Bu32} {x:Btypeidx} {i:Bfieldidx}} => STRUCT_GET_instr(?(U_sx), x, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:157.5-157.57 - prod{x : idx, i : fieldidx} {{0xFB} {`%`_u32(5):Bu32} {x:Btypeidx} {i:Bfieldidx}} => `STRUCT.SET`_instr(x, i) + prod{x : idx, i : fieldidx} {{0xFB} {mk_uN_u32(5):Bu32} {x:Btypeidx} {i:Bfieldidx}} => STRUCT_SET_instr(x, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:161.5-161.42 - prod{x : idx} {{0xFB} {`%`_u32(6):Bu32} {x:Btypeidx}} => `ARRAY.NEW`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(6):Bu32} {x:Btypeidx}} => ARRAY_NEW_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:162.5-162.50 - prod{x : idx} {{0xFB} {`%`_u32(7):Bu32} {x:Btypeidx}} => `ARRAY.NEW_DEFAULT`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(7):Bu32} {x:Btypeidx}} => ARRAY_NEW_DEFAULT_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:163.5-163.57 - prod{x : idx, v_n : n} {{0xFB} {`%`_u32(8):Bu32} {x:Btypeidx} {`%`_u32(v_n):Bu32}} => `ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n)) + prod{x : idx, v_n : n} {{0xFB} {mk_uN_u32(8):Bu32} {x:Btypeidx} {mk_uN_u32(v_n):Bu32}} => ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:164.5-164.60 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(9):Bu32} {x:Btypeidx} {y:Bdataidx}} => `ARRAY.NEW_DATA`_instr(x, y) + prod{x : idx, y : idx} {{0xFB} {mk_uN_u32(9):Bu32} {x:Btypeidx} {y:Bdataidx}} => ARRAY_NEW_DATA_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:165.5-165.61 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(10):Bu32} {x:Btypeidx} {y:Belemidx}} => `ARRAY.NEW_ELEM`_instr(x, y) + prod{x : idx, y : idx} {{0xFB} {mk_uN_u32(10):Bu32} {x:Btypeidx} {y:Belemidx}} => ARRAY_NEW_ELEM_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:166.5-166.43 - prod{x : idx} {{0xFB} {`%`_u32(11):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(), x) + prod{x : idx} {{0xFB} {mk_uN_u32(11):Bu32} {x:Btypeidx}} => ARRAY_GET_instr(?(), x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:167.5-167.45 - prod{x : idx} {{0xFB} {`%`_u32(12):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(S_sx), x) + prod{x : idx} {{0xFB} {mk_uN_u32(12):Bu32} {x:Btypeidx}} => ARRAY_GET_instr(?(S_sx), x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:168.5-168.45 - prod{x : idx} {{0xFB} {`%`_u32(13):Bu32} {x:Btypeidx}} => `ARRAY.GET`_instr(?(U_sx), x) + prod{x : idx} {{0xFB} {mk_uN_u32(13):Bu32} {x:Btypeidx}} => ARRAY_GET_instr(?(U_sx), x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:169.5-169.43 - prod{x : idx} {{0xFB} {`%`_u32(14):Bu32} {x:Btypeidx}} => `ARRAY.SET`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(14):Bu32} {x:Btypeidx}} => ARRAY_SET_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:170.5-170.30 - prod {{0xFB} {`%`_u32(15):Bu32}} => `ARRAY.LEN`_instr + prod {{0xFB} {mk_uN_u32(15):Bu32}} => ARRAY_LEN_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:171.5-171.44 - prod{x : idx} {{0xFB} {`%`_u32(16):Bu32} {x:Btypeidx}} => `ARRAY.FILL`_instr(x) + prod{x : idx} {{0xFB} {mk_uN_u32(16):Bu32} {x:Btypeidx}} => ARRAY_FILL_instr(x) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:172.5-172.65 - prod{x_1 : idx, x_2 : idx} {{0xFB} {`%`_u32(17):Bu32} {x_1:Btypeidx} {x_2:Btypeidx}} => `ARRAY.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{0xFB} {mk_uN_u32(17):Bu32} {x_1:Btypeidx} {x_2:Btypeidx}} => ARRAY_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:173.5-173.62 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(18):Bu32} {x:Btypeidx} {y:Bdataidx}} => `ARRAY.INIT_DATA`_instr(x, y) + prod{x : idx, y : idx} {{0xFB} {mk_uN_u32(18):Bu32} {x:Btypeidx} {y:Bdataidx}} => ARRAY_INIT_DATA_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:174.5-174.62 - prod{x : idx, y : idx} {{0xFB} {`%`_u32(19):Bu32} {x:Btypeidx} {y:Belemidx}} => `ARRAY.INIT_ELEM`_instr(x, y) + prod{x : idx, y : idx} {{0xFB} {mk_uN_u32(19):Bu32} {x:Btypeidx} {y:Belemidx}} => ARRAY_INIT_ELEM_instr(x, y) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:178.5-178.39 - prod {{0xFB} {`%`_u32(26):Bu32}} => `ANY.CONVERT_EXTERN`_instr + prod {{0xFB} {mk_uN_u32(26):Bu32}} => ANY_CONVERT_EXTERN_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:179.5-179.39 - prod {{0xFB} {`%`_u32(27):Bu32}} => `EXTERN.CONVERT_ANY`_instr + prod {{0xFB} {mk_uN_u32(27):Bu32}} => EXTERN_CONVERT_ANY_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:183.5-183.28 - prod {{0xFB} {`%`_u32(28):Bu32}} => `REF.I31`_instr + prod {{0xFB} {mk_uN_u32(28):Bu32}} => REF_I31_instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:184.5-184.30 - prod {{0xFB} {`%`_u32(29):Bu32}} => `I31.GET`_instr(S_sx) + prod {{0xFB} {mk_uN_u32(29):Bu32}} => I31_GET_instr(S_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:185.5-185.30 - prod {{0xFB} {`%`_u32(30):Bu32}} => `I31.GET`_instr(U_sx) + prod {{0xFB} {mk_uN_u32(30):Bu32}} => I31_GET_instr(U_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:192.5-192.31 prod{i : i32} {{0x41} {i:Bi32}} => CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, i)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:193.5-193.31 @@ -17063,15 +22120,15 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:277.5-277.28 prod 0x7B => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:281.5-281.31 - prod 0xC0 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(8)))) + prod 0xC0 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(mk_sz_sz(8)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:282.5-282.32 - prod 0xC1 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(16)))) + prod 0xC1 => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(mk_sz_sz(16)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:286.5-286.31 - prod 0xC2 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(8)))) + prod 0xC2 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(8)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:287.5-287.32 - prod 0xC3 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(16)))) + prod 0xC3 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(16)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:288.5-288.32 - prod 0xC4 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(32)))) + prod 0xC4 => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(32)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:292.5-292.26 prod 0x7C => BINOP_instr(I64_numtype, mk_binop__0_binop_(I64_Inn, ADD_binop_Inn)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:293.5-293.26 @@ -17209,533 +22266,533 @@ grammar Binstr : instr ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:375.5-375.38 prod 0xBF => CVTOP_instr(F64_numtype, I64_numtype, mk_cvtop___1_cvtop__(I64_Inn, F64_Fnn, REINTERPRET_cvtop__Inn_1_Fnn_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:379.5-379.45 - prod {{0xFC} {`%`_u32(0):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) + prod {{0xFC} {mk_uN_u32(0):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:380.5-380.45 - prod {{0xFC} {`%`_u32(1):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) + prod {{0xFC} {mk_uN_u32(1):Bu32}} => CVTOP_instr(I32_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:381.5-381.45 - prod {{0xFC} {`%`_u32(2):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) + prod {{0xFC} {mk_uN_u32(2):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:382.5-382.45 - prod {{0xFC} {`%`_u32(3):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) + prod {{0xFC} {mk_uN_u32(3):Bu32}} => CVTOP_instr(I32_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I32_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:383.5-383.45 - prod {{0xFC} {`%`_u32(4):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) + prod {{0xFC} {mk_uN_u32(4):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:384.5-384.45 - prod {{0xFC} {`%`_u32(5):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) + prod {{0xFC} {mk_uN_u32(5):Bu32}} => CVTOP_instr(I64_numtype, F32_numtype, mk_cvtop___2_cvtop__(F32_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:385.5-385.45 - prod {{0xFC} {`%`_u32(6):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) + prod {{0xFC} {mk_uN_u32(6):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:386.5-386.45 - prod {{0xFC} {`%`_u32(7):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) + prod {{0xFC} {mk_uN_u32(7):Bu32}} => CVTOP_instr(I64_numtype, F64_numtype, mk_cvtop___2_cvtop__(F64_Fnn, I64_Inn, TRUNC_SAT_cvtop__Fnn_1_Inn_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:396.5-396.50 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(0):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(0):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:397.5-397.70 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(1):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(1):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(8), 8, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:398.5-398.70 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(2):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(2):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(8), 8, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:399.5-399.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(3):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(3):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(16), 4, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:400.5-400.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(4):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(4):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(16), 4, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:401.5-401.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(5):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(5):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(32), 2, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:402.5-402.71 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(6):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(6):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(32), 2, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:403.5-403.61 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(7):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(8))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(7):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(8))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:404.5-404.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(8):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(16))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(8):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(16))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:405.5-405.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(9):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(32))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(9):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(32))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:406.5-406.63 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(10):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(64))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(10):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(64))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:407.5-407.52 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(11):Bu32} {(x, ao):Bmemarg}} => VSTORE_instr(V128_vectype, x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(11):Bu32} {(x, ao):Bmemarg}} => VSTORE_instr(V128_vectype, x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:408.5-408.72 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(84):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(84):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(8), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:409.5-409.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(85):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(85):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(16), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:410.5-410.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(86):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(86):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(32), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:411.5-411.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(87):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(87):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(64), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:412.5-412.73 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(88):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(88):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(8), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:413.5-413.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(89):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(89):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(16), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:414.5-414.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(90):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(90):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(32), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:415.5-415.74 - prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {`%`_u32(91):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{0xFD} {mk_uN_u32(91):Bu32} {(x, ao):Bmemarg} {i:Blaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(64), x, ao, i) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:416.5-416.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(92):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(32))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(92):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(32))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:417.5-417.62 - prod{x : idx, ao : memarg} {{0xFD} {`%`_u32(93):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(64))), x, ao) + prod{x : idx, ao : memarg} {{0xFD} {mk_uN_u32(93):Bu32} {(x, ao):Bmemarg}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(64))), x, ao) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:421.5-421.72 - prod{b_lst : byte*} {{0xFD} {`%`_u32(12):Bu32} {b:Bbyte^16{b <- b_lst}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, b_lst)) + prod{b_lst : byte*} {{0xFD} {mk_uN_u32(12):Bu32} {b:Bbyte^16{b <- b_lst}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, b_lst)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:425.5-425.61 - prod{l_lst : labelidx*} {{0xFD} {`%`_u32(13):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx^16{l <- l_lst}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_laneidx($proj_uN_0(l).0)^16{l <- l_lst}) + prod{l_lst : labelidx*} {{0xFD} {mk_uN_u32(13):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx^16{l <- l_lst}}} => VSHUFFLE_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_uN_laneidx($proj_uN_0(l).0)^16{l <- l_lst}) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:426.5-426.49 - prod {{0xFD} {`%`_u32(14):Bu32}} => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) + prod {{0xFD} {mk_uN_u32(14):Bu32}} => VSWIZZLOP_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:427.5-427.58 - prod {{0xFD} {`%`_u32(256):Bu32}} => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) + prod {{0xFD} {mk_uN_u32(256):Bu32}} => VSWIZZLOP_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:431.5-431.38 - prod {{0xFD} {`%`_u32(15):Bu32}} => VSPLAT_instr(`%X%`_shape(I8_lanetype, `%`_dim(16))) + prod {{0xFD} {mk_uN_u32(15):Bu32}} => VSPLAT_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:432.5-432.38 - prod {{0xFD} {`%`_u32(16):Bu32}} => VSPLAT_instr(`%X%`_shape(I16_lanetype, `%`_dim(8))) + prod {{0xFD} {mk_uN_u32(16):Bu32}} => VSPLAT_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:433.5-433.38 - prod {{0xFD} {`%`_u32(17):Bu32}} => VSPLAT_instr(`%X%`_shape(I32_lanetype, `%`_dim(4))) + prod {{0xFD} {mk_uN_u32(17):Bu32}} => VSPLAT_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:434.5-434.38 - prod {{0xFD} {`%`_u32(18):Bu32}} => VSPLAT_instr(`%X%`_shape(I64_lanetype, `%`_dim(2))) + prod {{0xFD} {mk_uN_u32(18):Bu32}} => VSPLAT_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:435.5-435.38 - prod {{0xFD} {`%`_u32(19):Bu32}} => VSPLAT_instr(`%X%`_shape(F32_lanetype, `%`_dim(4))) + prod {{0xFD} {mk_uN_u32(19):Bu32}} => VSPLAT_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:436.5-436.38 - prod {{0xFD} {`%`_u32(20):Bu32}} => VSPLAT_instr(`%X%`_shape(F64_lanetype, `%`_dim(2))) + prod {{0xFD} {mk_uN_u32(20):Bu32}} => VSPLAT_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:440.5-440.60 - prod{l : labelidx} {{0xFD} {`%`_u32(21):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(21):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), ?(S_sx), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:441.5-441.60 - prod{l : labelidx} {{0xFD} {`%`_u32(22):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(22):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), ?(U_sx), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:442.5-442.58 - prod{l : labelidx} {{0xFD} {`%`_u32(23):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(23):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:443.5-443.60 - prod{l : labelidx} {{0xFD} {`%`_u32(24):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(24):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), ?(S_sx), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:444.5-444.60 - prod{l : labelidx} {{0xFD} {`%`_u32(25):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(25):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), ?(U_sx), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:445.5-445.58 - prod{l : labelidx} {{0xFD} {`%`_u32(26):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(26):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:446.5-446.58 - prod{l : labelidx} {{0xFD} {`%`_u32(27):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(27):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), ?(), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:447.5-447.58 - prod{l : labelidx} {{0xFD} {`%`_u32(28):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(28):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:448.5-448.58 - prod{l : labelidx} {{0xFD} {`%`_u32(29):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(29):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), ?(), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:449.5-449.58 - prod{l : labelidx} {{0xFD} {`%`_u32(30):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(30):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:450.5-450.58 - prod{l : labelidx} {{0xFD} {`%`_u32(31):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(31):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), ?(), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:451.5-451.58 - prod{l : labelidx} {{0xFD} {`%`_u32(32):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(32):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:452.5-452.58 - prod{l : labelidx} {{0xFD} {`%`_u32(33):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(33):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), ?(), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:453.5-453.58 - prod{l : labelidx} {{0xFD} {`%`_u32(34):Bu32} {`%`_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%`_laneidx($proj_uN_0(l).0)) + prod{l : labelidx} {{0xFD} {mk_uN_u32(34):Bu32} {mk_uN_laneidx($proj_uN_0(l).0):Blaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_uN_laneidx($proj_uN_0(l).0)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:457.5-457.41 - prod {{0xFD} {`%`_u32(35):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(35):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:458.5-458.41 - prod {{0xFD} {`%`_u32(36):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(36):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:459.5-459.43 - prod {{0xFD} {`%`_u32(37):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(37):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:460.5-460.43 - prod {{0xFD} {`%`_u32(38):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(38):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:461.5-461.43 - prod {{0xFD} {`%`_u32(39):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(39):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:462.5-462.43 - prod {{0xFD} {`%`_u32(40):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(40):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:463.5-463.43 - prod {{0xFD} {`%`_u32(41):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(41):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:464.5-464.43 - prod {{0xFD} {`%`_u32(42):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(42):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:465.5-465.43 - prod {{0xFD} {`%`_u32(43):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(43):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:466.5-466.43 - prod {{0xFD} {`%`_u32(44):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(44):Bu32}} => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:470.5-470.41 - prod {{0xFD} {`%`_u32(45):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(45):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:471.5-471.41 - prod {{0xFD} {`%`_u32(46):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(46):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:472.5-472.43 - prod {{0xFD} {`%`_u32(47):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(47):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:473.5-473.43 - prod {{0xFD} {`%`_u32(48):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(48):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:474.5-474.43 - prod {{0xFD} {`%`_u32(49):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(49):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:475.5-475.43 - prod {{0xFD} {`%`_u32(50):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(50):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:476.5-476.43 - prod {{0xFD} {`%`_u32(51):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(51):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:477.5-477.43 - prod {{0xFD} {`%`_u32(52):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(52):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:478.5-478.43 - prod {{0xFD} {`%`_u32(53):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(53):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:479.5-479.43 - prod {{0xFD} {`%`_u32(54):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(54):Bu32}} => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:483.5-483.41 - prod {{0xFD} {`%`_u32(55):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(55):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:484.5-484.41 - prod {{0xFD} {`%`_u32(56):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(56):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:485.5-485.43 - prod {{0xFD} {`%`_u32(57):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(57):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:486.5-486.43 - prod {{0xFD} {`%`_u32(58):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(58):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:487.5-487.43 - prod {{0xFD} {`%`_u32(59):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(59):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:488.5-488.43 - prod {{0xFD} {`%`_u32(60):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(60):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:489.5-489.43 - prod {{0xFD} {`%`_u32(61):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(61):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:490.5-490.43 - prod {{0xFD} {`%`_u32(62):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(62):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:491.5-491.43 - prod {{0xFD} {`%`_u32(63):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(63):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:492.5-492.43 - prod {{0xFD} {`%`_u32(64):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(64):Bu32}} => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:496.5-496.41 - prod {{0xFD} {`%`_u32(65):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(65):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:497.5-497.41 - prod {{0xFD} {`%`_u32(66):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(66):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:498.5-498.41 - prod {{0xFD} {`%`_u32(67):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(67):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:499.5-499.41 - prod {{0xFD} {`%`_u32(68):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(68):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:500.5-500.41 - prod {{0xFD} {`%`_u32(69):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(69):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:501.5-501.41 - prod {{0xFD} {`%`_u32(70):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(70):Bu32}} => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:505.5-505.41 - prod {{0xFD} {`%`_u32(71):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(71):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:506.5-506.41 - prod {{0xFD} {`%`_u32(72):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(72):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:507.5-507.41 - prod {{0xFD} {`%`_u32(73):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(73):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:508.5-508.41 - prod {{0xFD} {`%`_u32(74):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(74):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:509.5-509.41 - prod {{0xFD} {`%`_u32(75):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(75):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:510.5-510.41 - prod {{0xFD} {`%`_u32(76):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(76):Bu32}} => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:514.5-514.36 - prod {{0xFD} {`%`_u32(77):Bu32}} => VVUNOP_instr(V128_vectype, NOT_vvunop) + prod {{0xFD} {mk_uN_u32(77):Bu32}} => VVUNOP_instr(V128_vectype, NOT_vvunop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:518.5-518.37 - prod {{0xFD} {`%`_u32(78):Bu32}} => VVBINOP_instr(V128_vectype, AND_vvbinop) + prod {{0xFD} {mk_uN_u32(78):Bu32}} => VVBINOP_instr(V128_vectype, AND_vvbinop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:519.5-519.40 - prod {{0xFD} {`%`_u32(79):Bu32}} => VVBINOP_instr(V128_vectype, ANDNOT_vvbinop) + prod {{0xFD} {mk_uN_u32(79):Bu32}} => VVBINOP_instr(V128_vectype, ANDNOT_vvbinop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:520.5-520.36 - prod {{0xFD} {`%`_u32(80):Bu32}} => VVBINOP_instr(V128_vectype, OR_vvbinop) + prod {{0xFD} {mk_uN_u32(80):Bu32}} => VVBINOP_instr(V128_vectype, OR_vvbinop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:521.5-521.37 - prod {{0xFD} {`%`_u32(81):Bu32}} => VVBINOP_instr(V128_vectype, XOR_vvbinop) + prod {{0xFD} {mk_uN_u32(81):Bu32}} => VVBINOP_instr(V128_vectype, XOR_vvbinop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:525.5-525.44 - prod {{0xFD} {`%`_u32(82):Bu32}} => VVTERNOP_instr(V128_vectype, BITSELECT_vvternop) + prod {{0xFD} {mk_uN_u32(82):Bu32}} => VVTERNOP_instr(V128_vectype, BITSELECT_vvternop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:529.5-529.43 - prod {{0xFD} {`%`_u32(83):Bu32}} => VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop) + prod {{0xFD} {mk_uN_u32(83):Bu32}} => VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:533.5-533.41 - prod {{0xFD} {`%`_u32(96):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(96):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:534.5-534.41 - prod {{0xFD} {`%`_u32(97):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(97):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:535.5-535.44 - prod {{0xFD} {`%`_u32(98):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(98):Bu32}} => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:539.5-539.48 - prod {{0xFD} {`%`_u32(99):Bu32}} => VTESTOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(99):Bu32}} => VTESTOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:543.5-543.41 - prod {{0xFD} {`%`_u32(100):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16)))) + prod {{0xFD} {mk_uN_u32(100):Bu32}} => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:547.5-547.53 - prod {{0xFD} {`%`_u32(101):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), S_sx) + prod {{0xFD} {mk_uN_u32(101):Bu32}} => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), S_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:548.5-548.53 - prod {{0xFD} {`%`_u32(102):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), U_sx) + prod {{0xFD} {mk_uN_u32(102):Bu32}} => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), U_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:552.5-552.45 - prod {{0xFD} {`%`_u32(107):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(107):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:553.5-553.47 - prod {{0xFD} {`%`_u32(108):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(108):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:554.5-554.47 - prod {{0xFD} {`%`_u32(109):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(109):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:558.5-558.43 - prod {{0xFD} {`%`_u32(110):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(110):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:559.5-559.49 - prod {{0xFD} {`%`_u32(111):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(111):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:560.5-560.49 - prod {{0xFD} {`%`_u32(112):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(112):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:561.5-561.43 - prod {{0xFD} {`%`_u32(113):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(113):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:562.5-562.49 - prod {{0xFD} {`%`_u32(114):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(114):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:563.5-563.49 - prod {{0xFD} {`%`_u32(115):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(115):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:564.5-564.45 - prod {{0xFD} {`%`_u32(118):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(118):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:565.5-565.45 - prod {{0xFD} {`%`_u32(119):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(119):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:566.5-566.45 - prod {{0xFD} {`%`_u32(120):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(120):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:567.5-567.45 - prod {{0xFD} {`%`_u32(121):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(121):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:568.5-568.46 - prod {{0xFD} {`%`_u32(123):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(123):Bu32}} => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:572.5-572.70 - prod {{0xFD} {`%`_u32(124):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + prod {{0xFD} {mk_uN_u32(124):Bu32}} => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:573.5-573.70 - prod {{0xFD} {`%`_u32(125):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) + prod {{0xFD} {mk_uN_u32(125):Bu32}} => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:577.5-577.42 - prod {{0xFD} {`%`_u32(128):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(128):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:578.5-578.42 - prod {{0xFD} {`%`_u32(129):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(129):Bu32}} => VUNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:582.5-582.53 - prod {{0xFD} {`%`_u32(130):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(130):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:583.5-583.43 - prod {{0xFD} {`%`_u32(142):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(142):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:584.5-584.49 - prod {{0xFD} {`%`_u32(143):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(143):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:585.5-585.49 - prod {{0xFD} {`%`_u32(144):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(144):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:586.5-586.43 - prod {{0xFD} {`%`_u32(145):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(145):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:587.5-587.49 - prod {{0xFD} {`%`_u32(146):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(146):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:588.5-588.49 - prod {{0xFD} {`%`_u32(147):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(147):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:589.5-589.43 - prod {{0xFD} {`%`_u32(149):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(149):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:590.5-590.45 - prod {{0xFD} {`%`_u32(150):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(150):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:591.5-591.45 - prod {{0xFD} {`%`_u32(151):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(151):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:592.5-592.45 - prod {{0xFD} {`%`_u32(152):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(152):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:593.5-593.45 - prod {{0xFD} {`%`_u32(153):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(153):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:594.5-594.46 - prod {{0xFD} {`%`_u32(155):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(155):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:595.5-595.57 - prod {{0xFD} {`%`_u32(273):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(273):Bu32}} => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:599.5-599.49 - prod {{0xFD} {`%`_u32(131):Bu32}} => VTESTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(131):Bu32}} => VTESTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:603.5-603.41 - prod {{0xFD} {`%`_u32(132):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8)))) + prod {{0xFD} {mk_uN_u32(132):Bu32}} => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:607.5-607.53 - prod {{0xFD} {`%`_u32(133):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), S_sx) + prod {{0xFD} {mk_uN_u32(133):Bu32}} => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), S_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:608.5-608.53 - prod {{0xFD} {`%`_u32(134):Bu32}} => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), U_sx) + prod {{0xFD} {mk_uN_u32(134):Bu32}} => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), U_sx) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:612.5-612.63 - prod {{0xFD} {`%`_u32(135):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(135):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:613.5-613.64 - prod {{0xFD} {`%`_u32(136):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(136):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:614.5-614.63 - prod {{0xFD} {`%`_u32(137):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(137):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:615.5-615.64 - prod {{0xFD} {`%`_u32(138):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(138):Bu32}} => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:619.5-619.45 - prod {{0xFD} {`%`_u32(139):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(139):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:620.5-620.47 - prod {{0xFD} {`%`_u32(140):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(140):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:621.5-621.47 - prod {{0xFD} {`%`_u32(141):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(141):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:625.5-625.66 - prod {{0xFD} {`%`_u32(156):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(156):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:626.5-626.67 - prod {{0xFD} {`%`_u32(157):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(157):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:627.5-627.66 - prod {{0xFD} {`%`_u32(158):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(158):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:628.5-628.67 - prod {{0xFD} {`%`_u32(159):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(159):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:629.5-629.67 - prod {{0xFD} {`%`_u32(274):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + prod {{0xFD} {mk_uN_u32(274):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:633.5-633.70 - prod {{0xFD} {`%`_u32(126):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + prod {{0xFD} {mk_uN_u32(126):Bu32}} => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:634.5-634.70 - prod {{0xFD} {`%`_u32(127):Bu32}} => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) + prod {{0xFD} {mk_uN_u32(127):Bu32}} => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:638.5-638.42 - prod {{0xFD} {`%`_u32(160):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(160):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:639.5-639.42 - prod {{0xFD} {`%`_u32(161):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(161):Bu32}} => VUNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:643.5-643.49 - prod {{0xFD} {`%`_u32(163):Bu32}} => VTESTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(163):Bu32}} => VTESTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:647.5-647.41 - prod {{0xFD} {`%`_u32(164):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4)))) + prod {{0xFD} {mk_uN_u32(164):Bu32}} => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:651.5-651.63 - prod {{0xFD} {`%`_u32(167):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(167):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:652.5-652.64 - prod {{0xFD} {`%`_u32(168):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(168):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:653.5-653.63 - prod {{0xFD} {`%`_u32(169):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(169):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:654.5-654.64 - prod {{0xFD} {`%`_u32(170):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(170):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:658.5-658.45 - prod {{0xFD} {`%`_u32(171):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(171):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:659.5-659.49 - prod {{0xFD} {`%`_u32(172):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(172):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:660.5-660.49 - prod {{0xFD} {`%`_u32(173):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(173):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:664.5-664.43 - prod {{0xFD} {`%`_u32(174):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(174):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:665.5-665.43 - prod {{0xFD} {`%`_u32(177):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(177):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:666.5-666.43 - prod {{0xFD} {`%`_u32(181):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(181):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:667.5-667.45 - prod {{0xFD} {`%`_u32(182):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(182):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:668.5-668.45 - prod {{0xFD} {`%`_u32(183):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(183):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:669.5-669.45 - prod {{0xFD} {`%`_u32(184):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(184):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:670.5-670.45 - prod {{0xFD} {`%`_u32(185):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(185):Bu32}} => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:674.5-674.59 - prod {{0xFD} {`%`_u32(186):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + prod {{0xFD} {mk_uN_u32(186):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:675.5-675.66 - prod {{0xFD} {`%`_u32(188):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(188):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:676.5-676.67 - prod {{0xFD} {`%`_u32(189):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(189):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:677.5-677.66 - prod {{0xFD} {`%`_u32(190):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(190):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:678.5-678.67 - prod {{0xFD} {`%`_u32(191):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(191):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:682.5-682.72 - prod {{0xFD} {`%`_u32(275):Bu32}} => VEXTTERNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) + prod {{0xFD} {mk_uN_u32(275):Bu32}} => VEXTTERNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:686.5-686.42 - prod {{0xFD} {`%`_u32(192):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(192):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:687.5-687.42 - prod {{0xFD} {`%`_u32(193):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(193):Bu32}} => VUNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:691.5-691.49 - prod {{0xFD} {`%`_u32(195):Bu32}} => VTESTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(195):Bu32}} => VTESTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:695.5-695.41 - prod {{0xFD} {`%`_u32(196):Bu32}} => VBITMASK_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2)))) + prod {{0xFD} {mk_uN_u32(196):Bu32}} => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:699.5-699.63 - prod {{0xFD} {`%`_u32(199):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(199):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:700.5-700.64 - prod {{0xFD} {`%`_u32(200):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(200):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:701.5-701.63 - prod {{0xFD} {`%`_u32(201):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(201):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:702.5-702.64 - prod {{0xFD} {`%`_u32(202):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(202):Bu32}} => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:706.5-706.45 - prod {{0xFD} {`%`_u32(203):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(203):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:707.5-707.49 - prod {{0xFD} {`%`_u32(204):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(204):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:708.5-708.49 - prod {{0xFD} {`%`_u32(205):Bu32}} => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) + prod {{0xFD} {mk_uN_u32(205):Bu32}} => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:712.5-712.43 - prod {{0xFD} {`%`_u32(206):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(206):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:713.5-713.43 - prod {{0xFD} {`%`_u32(209):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(209):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:714.5-714.43 - prod {{0xFD} {`%`_u32(213):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(213):Bu32}} => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:718.5-718.42 - prod {{0xFD} {`%`_u32(214):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(214):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:719.5-719.42 - prod {{0xFD} {`%`_u32(215):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(215):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:720.5-720.46 - prod {{0xFD} {`%`_u32(216):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(216):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:721.5-721.46 - prod {{0xFD} {`%`_u32(217):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(217):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:722.5-722.46 - prod {{0xFD} {`%`_u32(218):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(218):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:723.5-723.46 - prod {{0xFD} {`%`_u32(219):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) + prod {{0xFD} {mk_uN_u32(219):Bu32}} => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:727.5-727.66 - prod {{0xFD} {`%`_u32(220):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod {{0xFD} {mk_uN_u32(220):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:728.5-728.67 - prod {{0xFD} {`%`_u32(221):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod {{0xFD} {mk_uN_u32(221):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:729.5-729.66 - prod {{0xFD} {`%`_u32(222):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod {{0xFD} {mk_uN_u32(222):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:730.5-730.67 - prod {{0xFD} {`%`_u32(223):Bu32}} => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod {{0xFD} {mk_uN_u32(223):Bu32}} => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:734.5-734.43 - prod {{0xFD} {`%`_u32(103):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(103):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:735.5-735.44 - prod {{0xFD} {`%`_u32(104):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(104):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:736.5-736.44 - prod {{0xFD} {`%`_u32(105):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(105):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:737.5-737.46 - prod {{0xFD} {`%`_u32(106):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(106):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:738.5-738.42 - prod {{0xFD} {`%`_u32(224):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(224):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:739.5-739.42 - prod {{0xFD} {`%`_u32(225):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(225):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:740.5-740.43 - prod {{0xFD} {`%`_u32(227):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(227):Bu32}} => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:744.5-744.43 - prod {{0xFD} {`%`_u32(228):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(228):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:745.5-745.43 - prod {{0xFD} {`%`_u32(229):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(229):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:746.5-746.43 - prod {{0xFD} {`%`_u32(230):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(230):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:747.5-747.43 - prod {{0xFD} {`%`_u32(231):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(231):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:748.5-748.43 - prod {{0xFD} {`%`_u32(232):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(232):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:749.5-749.43 - prod {{0xFD} {`%`_u32(233):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(233):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:750.5-750.44 - prod {{0xFD} {`%`_u32(234):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(234):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:751.5-751.44 - prod {{0xFD} {`%`_u32(235):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(235):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:752.5-752.51 - prod {{0xFD} {`%`_u32(269):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(269):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:753.5-753.51 - prod {{0xFD} {`%`_u32(270):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(270):Bu32}} => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:757.5-757.53 - prod {{0xFD} {`%`_u32(261):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(261):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:758.5-758.54 - prod {{0xFD} {`%`_u32(262):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(262):Bu32}} => VTERNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:762.5-762.43 - prod {{0xFD} {`%`_u32(116):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(116):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:763.5-763.44 - prod {{0xFD} {`%`_u32(117):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(117):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:764.5-764.44 - prod {{0xFD} {`%`_u32(122):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(122):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:765.5-765.46 - prod {{0xFD} {`%`_u32(148):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(148):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:766.5-766.42 - prod {{0xFD} {`%`_u32(236):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(236):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:767.5-767.42 - prod {{0xFD} {`%`_u32(237):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(237):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:768.5-768.43 - prod {{0xFD} {`%`_u32(239):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(239):Bu32}} => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:772.5-772.43 - prod {{0xFD} {`%`_u32(240):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(240):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:773.5-773.43 - prod {{0xFD} {`%`_u32(241):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(241):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:774.5-774.43 - prod {{0xFD} {`%`_u32(242):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(242):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:775.5-775.43 - prod {{0xFD} {`%`_u32(243):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(243):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:776.5-776.43 - prod {{0xFD} {`%`_u32(244):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(244):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:777.5-777.43 - prod {{0xFD} {`%`_u32(245):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(245):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:778.5-778.44 - prod {{0xFD} {`%`_u32(246):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(246):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:779.5-779.44 - prod {{0xFD} {`%`_u32(247):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(247):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:780.5-780.51 - prod {{0xFD} {`%`_u32(271):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(271):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:781.5-781.51 - prod {{0xFD} {`%`_u32(272):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(272):Bu32}} => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:785.5-785.53 - prod {{0xFD} {`%`_u32(263):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(263):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:786.5-786.54 - prod {{0xFD} {`%`_u32(264):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) + prod {{0xFD} {mk_uN_u32(264):Bu32}} => VTERNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:787.5-787.59 - prod {{0xFD} {`%`_u32(265):Bu32}} => VTERNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(265):Bu32}} => VTERNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:788.5-788.59 - prod {{0xFD} {`%`_u32(266):Bu32}} => VTERNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(266):Bu32}} => VTERNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:789.5-789.59 - prod {{0xFD} {`%`_u32(267):Bu32}} => VTERNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(267):Bu32}} => VTERNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:790.5-790.59 - prod {{0xFD} {`%`_u32(268):Bu32}} => VTERNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) + prod {{0xFD} {mk_uN_u32(268):Bu32}} => VTERNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:794.5-794.61 - prod {{0xFD} {`%`_u32(94):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) + prod {{0xFD} {mk_uN_u32(94):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:795.5-795.61 - prod {{0xFD} {`%`_u32(95):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) + prod {{0xFD} {mk_uN_u32(95):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:796.5-796.62 - prod {{0xFD} {`%`_u32(248):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) + prod {{0xFD} {mk_uN_u32(248):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:797.5-797.62 - prod {{0xFD} {`%`_u32(249):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) + prod {{0xFD} {mk_uN_u32(249):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:798.5-798.60 - prod {{0xFD} {`%`_u32(250):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) + prod {{0xFD} {mk_uN_u32(250):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:799.5-799.60 - prod {{0xFD} {`%`_u32(251):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) + prod {{0xFD} {mk_uN_u32(251):Bu32}} => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:800.5-800.67 - prod {{0xFD} {`%`_u32(252):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) + prod {{0xFD} {mk_uN_u32(252):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:801.5-801.67 - prod {{0xFD} {`%`_u32(253):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) + prod {{0xFD} {mk_uN_u32(253):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:802.5-802.64 - prod {{0xFD} {`%`_u32(254):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) + prod {{0xFD} {mk_uN_u32(254):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:803.5-803.64 - prod {{0xFD} {`%`_u32(255):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) + prod {{0xFD} {mk_uN_u32(255):Bu32}} => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:804.5-804.66 - prod {{0xFD} {`%`_u32(257):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) + prod {{0xFD} {mk_uN_u32(257):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:805.5-805.66 - prod {{0xFD} {`%`_u32(258):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) + prod {{0xFD} {mk_uN_u32(258):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:806.5-806.71 - prod {{0xFD} {`%`_u32(259):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) + prod {{0xFD} {mk_uN_u32(259):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec:807.5-807.71 - prod {{0xFD} {`%`_u32(260):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) + prod {{0xFD} {mk_uN_u32(260):Bu32}} => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) } ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec @@ -17746,7 +22803,7 @@ grammar Bexpr : expr ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bsection_(v_N : N, syntax en, grammar BX : en*) : en* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{en_lst : en*, len : nat} {{`%`_byte(v_N):Bbyte} {`%`_u32(len):Bu32} {en_lst:BX}} => en_lst + prod{en_lst : en*, len : nat} {{mk_byte_byte(v_N):Bbyte} {mk_uN_u32(len):Bu32} {en_lst:BX}} => en_lst -- if (len = 0) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec prod eps => [] @@ -17789,8 +22846,8 @@ grammar Bfuncsec : typeidx* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Btable : table ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{tt : tabletype, ht : heaptype, at : addrtype, lim : limits} tt:Btabletype => TABLE_table(tt, [`REF.NULL`_instr(ht)]) - -- if (tt = `%%%`_tabletype(at, lim, REF_reftype(?(NULL_null), ht))) + prod{tt : tabletype, ht : heaptype, at : addrtype, lim : limits} tt:Btabletype => TABLE_table(tt, [REF_NULL_instr(ht)]) + -- if (tt = mk_tabletype_tabletype(at, lim, REF_reftype(?(NULL_null), ht))) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec prod{tt : tabletype, e : expr} {{0x40} {0x00} {tt:Btabletype} {e:Bexpr}} => TABLE_table(tt, e) @@ -17847,21 +22904,21 @@ grammar Belemkind : reftype ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Belem : elem ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{y_lst : idx*, e_o : expr} {{`%`_u32(0):Bu32} {e_o:Bexpr} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(REF_reftype(?(), FUNC_heaptype), [`REF.FUNC`_instr(y)*{y <- y_lst}], ACTIVE_elemmode(`%`_tableidx(0), e_o)) + prod{y_lst : idx*, e_o : expr} {{mk_uN_u32(0):Bu32} {e_o:Bexpr} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(REF_reftype(?(), FUNC_heaptype), [REF_FUNC_instr(y)*{y <- y_lst}], ACTIVE_elemmode(mk_uN_tableidx(0), e_o)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, y_lst : idx*} {{`%`_u32(1):Bu32} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- y_lst}], PASSIVE_elemmode) + prod{rt : reftype, y_lst : idx*} {{mk_uN_u32(1):Bu32} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [REF_FUNC_instr(y)*{y <- y_lst}], PASSIVE_elemmode) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, y_lst : idx*, x : idx, e : expr} {{`%`_u32(2):Bu32} {x:Btableidx} {e:Bexpr} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- y_lst}], ACTIVE_elemmode(x, e)) + prod{rt : reftype, y_lst : idx*, x : idx, e : expr} {{mk_uN_u32(2):Bu32} {x:Btableidx} {e:Bexpr} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [REF_FUNC_instr(y)*{y <- y_lst}], ACTIVE_elemmode(x, e)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, y_lst : idx*} {{`%`_u32(3):Bu32} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [`REF.FUNC`_instr(y)*{y <- y_lst}], DECLARE_elemmode) + prod{rt : reftype, y_lst : idx*} {{mk_uN_u32(3):Bu32} {rt:Belemkind} {y_lst:Blist(syntax funcidx, grammar Bfuncidx)}} => ELEM_elem(rt, [REF_FUNC_instr(y)*{y <- y_lst}], DECLARE_elemmode) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{e_lst : expr*, e_O : expr} {{`%`_u32(4):Bu32} {e_O:Bexpr} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(REF_reftype(?(NULL_null), FUNC_heaptype), e_lst, ACTIVE_elemmode(`%`_tableidx(0), e_O)) + prod{e_lst : expr*, e_O : expr} {{mk_uN_u32(4):Bu32} {e_O:Bexpr} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(REF_reftype(?(NULL_null), FUNC_heaptype), e_lst, ACTIVE_elemmode(mk_uN_tableidx(0), e_O)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, e_lst : expr*} {{`%`_u32(5):Bu32} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, PASSIVE_elemmode) + prod{rt : reftype, e_lst : expr*} {{mk_uN_u32(5):Bu32} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, PASSIVE_elemmode) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, e_lst : expr*, x : idx, e_O : expr} {{`%`_u32(6):Bu32} {x:Btableidx} {e_O:Bexpr} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, ACTIVE_elemmode(x, e_O)) + prod{rt : reftype, e_lst : expr*, x : idx, e_O : expr} {{mk_uN_u32(6):Bu32} {x:Btableidx} {e_O:Bexpr} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, ACTIVE_elemmode(x, e_O)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{rt : reftype, e_lst : expr*} {{`%`_u32(7):Bu32} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, DECLARE_elemmode) + prod{rt : reftype, e_lst : expr*} {{mk_uN_u32(7):Bu32} {rt:Breftype} {e_lst:Blist(syntax expr, grammar Bexpr)}} => ELEM_elem(rt, e_lst, DECLARE_elemmode) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Belemsec : elem* @@ -17871,7 +22928,7 @@ grammar Belemsec : elem* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Blocals : local* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{t : valtype, v_n : n} {{`%`_u32(v_n):Bu32} {t:Bvaltype}} => LOCAL_local(t)^v_n{} + prod{t : valtype, v_n : n} {{mk_uN_u32(v_n):Bu32} {t:Bvaltype}} => LOCAL_local(t)^v_n{} ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bfunc : code @@ -17882,7 +22939,7 @@ grammar Bfunc : code ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bcode : code ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{v_code : code, len : nat} {{`%`_u32(len):Bu32} {v_code:Bfunc}} => v_code + prod{v_code : code, len : nat} {{mk_uN_u32(len):Bu32} {v_code:Bfunc}} => v_code -- if (len = 0) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec @@ -17893,11 +22950,11 @@ grammar Bcodesec : code* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bdata : data ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{b_lst : byte*, e : expr} {{`%`_u32(0):Bu32} {e:Bexpr} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, ACTIVE_datamode(`%`_memidx(0), e)) + prod{b_lst : byte*, e : expr} {{mk_uN_u32(0):Bu32} {e:Bexpr} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, ACTIVE_datamode(mk_uN_memidx(0), e)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{b_lst : byte*} {{`%`_u32(1):Bu32} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, PASSIVE_datamode) + prod{b_lst : byte*} {{mk_uN_u32(1):Bu32} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, PASSIVE_datamode) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{b_lst : byte*, x : idx, e : expr} {{`%`_u32(2):Bu32} {x:Bmemidx} {e:Bexpr} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, ACTIVE_datamode(x, e)) + prod{b_lst : byte*, x : idx, e : expr} {{mk_uN_u32(2):Bu32} {x:Bmemidx} {e:Bexpr} {b_lst:Blist(syntax byte, grammar Bbyte)}} => DATA_data(b_lst, ACTIVE_datamode(x, e)) ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bdatasec : data* @@ -17907,7 +22964,7 @@ grammar Bdatasec : data* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bdatacnt : u32* ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{v_n : n} `%`_u32(v_n):Bu32 => [`%`_u32(v_n)] + prod{v_n : n} mk_uN_u32(v_n):Bu32 => [mk_uN_u32(v_n)] ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bdatacntsec : u32? @@ -17937,17 +22994,18 @@ grammar Bversion : () ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec grammar Bmodule : module ;; ../../../../specification/wasm-3.0/5.4-binary.modules.spectec - prod{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, typeidx_lst : typeidx*, n_opt : n?, expr_lst : expr*, local_lst_lst : local**} {Bmagic Bversion {Bcustomsec*{}} {type_lst:Btypesec} {Bcustomsec*{}} {import_lst:Bimportsec} {Bcustomsec*{}} {typeidx_lst:Bfuncsec} {Bcustomsec*{}} {table_lst:Btablesec} {Bcustomsec*{}} {mem_lst:Bmemsec} {Bcustomsec*{}} {tag_lst:Btagsec} {Bcustomsec*{}} {global_lst:Bglobalsec} {Bcustomsec*{}} {export_lst:Bexportsec} {Bcustomsec*{}} {start_opt:Bstartsec} {Bcustomsec*{}} {elem_lst:Belemsec} {Bcustomsec*{}} {`%`_u32(v_n)?{v_n <- n_opt}:Bdatacntsec} {Bcustomsec*{}} {(local_lst, v_expr)*{v_expr <- expr_lst, local_lst <- local_lst_lst}:Bcodesec} {Bcustomsec*{}} {data_lst:Bdatasec} {Bcustomsec*{}}} => MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst)) + prod{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, typeidx_lst : typeidx*, n_opt : n?, expr_lst : expr*, local_lst_lst : local**, var_0 : dataidx*} {Bmagic Bversion {Bcustomsec*{}} {type_lst:Btypesec} {Bcustomsec*{}} {import_lst:Bimportsec} {Bcustomsec*{}} {typeidx_lst:Bfuncsec} {Bcustomsec*{}} {table_lst:Btablesec} {Bcustomsec*{}} {mem_lst:Bmemsec} {Bcustomsec*{}} {tag_lst:Btagsec} {Bcustomsec*{}} {global_lst:Bglobalsec} {Bcustomsec*{}} {export_lst:Bexportsec} {Bcustomsec*{}} {start_opt:Bstartsec} {Bcustomsec*{}} {elem_lst:Belemsec} {Bcustomsec*{}} {mk_uN_u32(v_n)?{v_n <- n_opt}:Bdatacntsec} {Bcustomsec*{}} {(local_lst, v_expr)*{v_expr <- expr_lst, local_lst <- local_lst_lst}:Bcodesec} {Bcustomsec*{}} {data_lst:Bdatasec} {Bcustomsec*{}}} => MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)) -- (if (v_n = |data_lst|))?{v_n <- n_opt} - -- if ((n_opt =/= ?()) \/ ($dataidx_funcs(func_lst) = [])) + -- if ((n_opt =/= ?()) \/ (var_0 = [])) -- (if (v_func = FUNC_func(v_typeidx, local_lst, v_expr)))*{v_expr <- expr_lst, v_func <- func_lst, local_lst <- local_lst_lst, v_typeidx <- typeidx_lst} + -- fun_dataidx_funcs: `%%`(func_lst, var_0) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tchar : char ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:(0x00 | ... | 0xD7FF) => `%`_char(``) + prod{`` : nat} ``:(0x00 | ... | 0xD7FF) => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec - prod{`` : nat} ``:(0xE000 | ... | 0x10FFFF) => `%`_char(``) + prod{`` : nat} ``:(0xE000 | ... | 0x10FFFF) => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec grammar Tsource : () @@ -17972,57 +23030,57 @@ grammar TfNplain : () ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tidchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x30 | ... | 0x39) => `%`_char(``) + prod{`` : nat} ``:(0x30 | ... | 0x39) => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x41 | ... | 0x5A) => `%`_char(``) + prod{`` : nat} ``:(0x41 | ... | 0x5A) => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:(0x61 | ... | 0x7A) => `%`_char(``) + prod{`` : nat} ``:(0x61 | ... | 0x7A) => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x21 => `%`_char(``) + prod{`` : nat} ``:0x21 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x23 => `%`_char(``) + prod{`` : nat} ``:0x23 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x24 => `%`_char(``) + prod{`` : nat} ``:0x24 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x25 => `%`_char(``) + prod{`` : nat} ``:0x25 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x26 => `%`_char(``) + prod{`` : nat} ``:0x26 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x27 => `%`_char(``) + prod{`` : nat} ``:0x27 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2A => `%`_char(``) + prod{`` : nat} ``:0x2A => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2B => `%`_char(``) + prod{`` : nat} ``:0x2B => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2D => `%`_char(``) + prod{`` : nat} ``:0x2D => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2E => `%`_char(``) + prod{`` : nat} ``:0x2E => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x2F => `%`_char(``) + prod{`` : nat} ``:0x2F => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3A => `%`_char(``) + prod{`` : nat} ``:0x3A => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3C => `%`_char(``) + prod{`` : nat} ``:0x3C => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3D => `%`_char(``) + prod{`` : nat} ``:0x3D => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3E => `%`_char(``) + prod{`` : nat} ``:0x3E => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x3F => `%`_char(``) + prod{`` : nat} ``:0x3F => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x40 => `%`_char(``) + prod{`` : nat} ``:0x40 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5C => `%`_char(``) + prod{`` : nat} ``:0x5C => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5E => `%`_char(``) + prod{`` : nat} ``:0x5E => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x5F => `%`_char(``) + prod{`` : nat} ``:0x5F => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x60 => `%`_char(``) + prod{`` : nat} ``:0x60 => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x7C => `%`_char(``) + prod{`` : nat} ``:0x7C => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{`` : nat} ``:0x7E => `%`_char(``) + prod{`` : nat} ``:0x7E => mk_char_char(``) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tdigit : nat @@ -18091,29 +23149,30 @@ grammar Thexnum : nat grammar Tstringchar : char ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod{c : char} c:Tchar => c - -- if (((($proj_char_0(c).0 >= 32) /\ ($proj_char_0(c).0 =/= 127)) /\ (c =/= `%`_char(34))) /\ (c =/= `%`_char(92))) + -- if (((($proj_char_0(c).0 >= 32) /\ ($proj_char_0(c).0 =/= 127)) /\ (c =/= mk_char_char(34))) /\ (c =/= mk_char_char(92))) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\t" => `%`_char(9) + prod "\\t" => mk_char_char(9) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\n" => `%`_char(10) + prod "\\n" => mk_char_char(10) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\r" => `%`_char(13) + prod "\\r" => mk_char_char(13) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\\"" => `%`_char(34) + prod "\\\"" => mk_char_char(34) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\'" => `%`_char(39) + prod "\\'" => mk_char_char(39) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod "\\\\" => `%`_char(92) + prod "\\\\" => mk_char_char(92) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n} {{"\\u{"} {v_n:Thexnum} {"}"}} => `%`_char(v_n) + prod{v_n : n} {{"\\u{"} {v_n:Thexnum} {"}"}} => mk_char_char(v_n) -- if ((v_n < 55296) \/ ((59392 <= v_n) /\ (v_n < 1114112))) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tstringelem : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c : char} c:Tstringchar => $utf8([c]) + prod{c : char, var_0 : byte*} c:Tstringchar => var_0 + -- fun_utf8: `%%`([c], var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [`%`_byte(((16 * h_1) + h_2))] + prod{h_1 : nat, h_2 : nat} {{"\\"} {h_1:Thexdigit} {h_2:Thexdigit}} => [mk_byte_byte(((16 * h_1) + h_2))] ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tstring : byte* @@ -18124,15 +23183,16 @@ grammar Tstring : byte* ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tname : name ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c_lst : char*, b_lst : byte*} b_lst:Tstring => `%`_name(c_lst) - -- if (b_lst = $utf8(c_lst)) + prod{c_lst : char*, b_lst : byte*, var_0 : byte*} b_lst:Tstring => mk_name_name(c_lst) + -- if (b_lst = var_0) + -- fun_utf8: `%%`(c_lst, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar Tid : name ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c_lst : char*} {{"$"} {c_lst:Tidchar+{}}} => `%`_name(c_lst) + prod{c_lst : char*} {{"$"} {c_lst:Tidchar+{}}} => mk_name_name(c_lst) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{c_lst : char*} {{"$"} {`%`_name(c_lst):Tname}} => `%`_name(c_lst) + prod{c_lst : char*} {{"$"} {mk_name_name(c_lst):Tname}} => mk_name_name(c_lst) -- if (|c_lst| > 0) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec @@ -18185,13 +23245,13 @@ grammar Tblockcomment : () grammar Tblockchar : () ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:61.5-61.47 prod{`` : char, c : char} ``:c:Tchar => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(40))) + -- if ((c =/= mk_char_char(59)) /\ (c =/= mk_char_char(40))) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:62.5-62.47 prod{`` : (), c : char} ``:{{";"+{}} {c:Tchar}} => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(41))) + -- if ((c =/= mk_char_char(59)) /\ (c =/= mk_char_char(41))) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:63.5-63.47 prod{`` : (), c : char} ``:{{"("+{}} {c:Tchar}} => (``, ()).1 - -- if ((c =/= `%`_char(59)) /\ (c =/= `%`_char(40))) + -- if ((c =/= mk_char_char(59)) /\ (c =/= mk_char_char(40))) ;; ../../../../specification/wasm-3.0/6.0-text.lexical.spectec:64.5-64.18 prod{`` : ()} ``:Tblockcomment => (``, ()).1 } @@ -18272,24 +23332,25 @@ grammar Tnum : nat ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TuN(v_N : N) : uN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n} v_n:Tnum => `%`_uN(v_n) + prod{v_n : n} v_n:Tnum => mk_uN_uN(v_n) -- if (v_n < (2 ^ v_N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n} {{"0x"} {v_n:Thexnum}} => `%`_uN(v_n) + prod{v_n : n} {{"0x"} {v_n:Thexnum}} => mk_uN_uN(v_n) -- if (v_n < (2 ^ v_N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TsN(v_N : N) : sN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{s : int, v_n : n} {{s:Tsign} {`%`_uN(v_n):TuN(v_N)}} => `%`_sN((s * (v_n : nat <:> int))) + prod{s : int, v_n : n} {{s:Tsign} {mk_uN_uN(v_n):TuN(v_N)}} => mk_sN_sN((s * (v_n : nat <:> int))) -- if ((- ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) <= (s * (v_n : nat <:> int))) /\ ((s * (v_n : nat <:> int)) < ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int))) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TiN(v_N : N) : iN ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n} `%`_uN(v_n):TuN(v_N) => `%`_iN(v_n) + prod{v_n : n} mk_uN_uN(v_n):TuN(v_N) => mk_uN_iN(v_n) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{i : sN} i:TsN(v_N) => `%`_iN($inv_signed_(v_N, $proj_sN_0(i).0)) + prod{i : sN, var_0 : nat} i:TsN(v_N) => mk_uN_iN(var_0) + -- fun_inv_signed_: `%%%`(v_N, $proj_sN_0(i).0, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec rec { @@ -18573,19 +23634,19 @@ grammar Tstoragetype_(v_I : I) : storagetype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tfieldtype_(v_I : I) : fieldtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{zt : storagetype} zt:Tstoragetype_(v_I) => `%%`_fieldtype(?(), zt) + prod{zt : storagetype} zt:Tstoragetype_(v_I) => mk_fieldtype_fieldtype(?(), zt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{zt : storagetype} {{"("} {"mut"} {zt:Tstoragetype_(v_I)} {")"}} => `%%`_fieldtype(?(MUT_mut), zt) + prod{zt : storagetype} {{"("} {"mut"} {zt:Tstoragetype_(v_I)} {")"}} => mk_fieldtype_fieldtype(?(MUT_mut), zt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tfield_(v_I : I) : (fieldtype, name?) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ft : fieldtype, id_opt : char?} {{"("} {"field"} {?(`%`_name(lift(id_opt))):Tid?{}} {ft:Tfieldtype_(v_I)} {")"}} => (ft, ?(`%`_name(lift(id_opt)))) + prod{ft : fieldtype, id_opt : char?} {{"("} {"field"} {?(mk_name_name(lift(id_opt))):Tid?{}} {ft:Tfieldtype_(v_I)} {")"}} => (ft, ?(mk_name_name(lift(id_opt)))) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tparam_(v_I : I) : (valtype, name?) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype, id_opt : char?} {{"("} {"param"} {?(`%`_name(lift(id_opt))):Tid?{}} {t:Tvaltype_(v_I)} {")"}} => (t, ?(`%`_name(lift(id_opt)))) + prod{t : valtype, id_opt : char?} {{"("} {"param"} {?(mk_name_name(lift(id_opt))):Tid?{}} {t:Tvaltype_(v_I)} {")"}} => (t, ?(mk_name_name(lift(id_opt)))) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tresult_(v_I : I) : valtype @@ -18595,11 +23656,11 @@ grammar Tresult_(v_I : I) : valtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tcomptype_(v_I : I) : (comptype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ft_lst : fieldtype*, id_opt_lst : char?*} {{"("} {"struct"} {(ft, ?(`%`_name(lift(id_opt))))*{ft <- ft_lst, id_opt <- id_opt_lst}:Tlist(syntax (fieldtype, name?), grammar Tfield_(v_I))} {")"}} => (STRUCT_comptype(`%`_list(ft_lst)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [?(`%`_name(lift(id_opt)))*{id_opt <- id_opt_lst}], TYPEDEFS []}) + prod{ft_lst : fieldtype*, id_opt_lst : char?*} {{"("} {"struct"} {(ft, ?(mk_name_name(lift(id_opt))))*{ft <- ft_lst, id_opt <- id_opt_lst}:Tlist(syntax (fieldtype, name?), grammar Tfield_(v_I))} {")"}} => (STRUCT_comptype(mk_list_list(ft_lst)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [?(mk_name_name(lift(id_opt)))*{id_opt <- id_opt_lst}], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{ft : fieldtype} {{"("} {"array"} {ft:Tfieldtype_(v_I)} {")"}} => (ARRAY_comptype(ft), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(`%`_name([]))]], TYPEDEFS []}) + prod{ft : fieldtype} {{"("} {"array"} {ft:Tfieldtype_(v_I)} {")"}} => (ARRAY_comptype(ft), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(mk_name_name([]))]], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t_1_lst : valtype*, t_2_lst : valtype*, id_opt_lst : char?*} {{"("} {"func"} {(t_1, ?(`%`_name(lift(id_opt))))*{id_opt <- id_opt_lst, t_1 <- t_1_lst}:Tlist(syntax (valtype, name?), grammar Tparam_(v_I))} {t_2_lst:Tlist(syntax valtype, grammar Tresult_(v_I))} {")"}} => (`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(`%`_name([]))]], TYPEDEFS []}) + prod{t_1_lst : valtype*, t_2_lst : valtype*, id_opt_lst : char?*} {{"("} {"func"} {(t_1, ?(mk_name_name(lift(id_opt))))*{id_opt <- id_opt_lst, t_1 <- t_1_lst}:Tlist(syntax (valtype, name?), grammar Tparam_(v_I))} {t_2_lst:Tlist(syntax valtype, grammar Tresult_(v_I))} {")"}} => (`FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [[?(mk_name_name([]))]], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tfinal : final @@ -18614,12 +23675,13 @@ grammar Tsubtype_(v_I : I) : (subtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Ttypedef_(v_I : I) : (subtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{st : subtype, I' : I, id_opt : char?} {{"("} {"type"} {?(`%`_name(lift(id_opt))):Tid?{}} {(st, I'):Tsubtype_(v_I)} {")"}} => (st, I' +++ {TYPES [?(`%`_name(lift(id_opt)))], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{st : subtype, I' : I, id_opt : char?} {{"("} {"type"} {?(mk_name_name(lift(id_opt))):Tid?{}} {(st, I'):Tsubtype_(v_I)} {")"}} => (st, I' +++ {TYPES [?(mk_name_name(lift(id_opt)))], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Trectype_(v_I : I) : (rectype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{st_lst : subtype*, I'_lst : I*} {{"("} {"rec"} {(st, I')*{I' <- I'_lst, st <- st_lst}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(v_I))} {")"}} => (REC_rectype(`%`_list(st_lst)), $concat_idctxt(I'_lst)) + prod{st_lst : subtype*, I'_lst : I*, var_0 : idctxt} {{"("} {"rec"} {(st, I')*{I' <- I'_lst, st <- st_lst}:Tlist(syntax (subtype, idctxt), grammar Ttypedef_(v_I))} {")"}} => (REC_rectype(mk_list_list(st_lst)), var_0) + -- fun_concat_idctxt: `%%`(I'_lst, var_0) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Taddrtype : addrtype @@ -18631,22 +23693,22 @@ grammar Taddrtype : addrtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tlimits : limits ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{v_n : n} `%`_u64(v_n):Tu64 => `[%..%]`_limits(`%`_u64(v_n), ?()) + prod{v_n : n} mk_uN_u64(v_n):Tu64 => mk_limits_limits(mk_uN_u64(v_n), ?()) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{v_n : n, v_m : m} {{`%`_u64(v_n):Tu64} {`%`_u64(v_m):Tu64}} => `[%..%]`_limits(`%`_u64(v_n), ?(`%`_u64(v_m))) + prod{v_n : n, v_m : m} {{mk_uN_u64(v_n):Tu64} {mk_uN_u64(v_m):Tu64}} => mk_limits_limits(mk_uN_u64(v_n), ?(mk_uN_u64(v_m))) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Ttypeuse_(v_I : I) : (typeidx, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec prod{x : idx, I' : I, st_lst : subtype*, i : n, t_1_lst : valtype*, t_2_lst : valtype*} {{"("} {"type"} {x:Ttypeidx_(v_I)} {")"}} => (x, I') - -- if (v_I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(`%`_list(st_lst)), i))) - -- if (st_lst[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)))) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))^|t_1_lst|{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (v_I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(mk_list_list(st_lst)), i))) + -- if (st_lst[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)))) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(mk_name_name([]))^|t_1_lst|{}, LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, I' : I, id_opt_lst : char?*, t_1_lst : valtype*, t_2_lst : valtype*, st_lst : subtype*, i : n} {{"("} {"type"} {x:Ttypeidx_(v_I)} {")"} {(t_1, ?(`%`_name(lift(id_opt))))*{id_opt <- id_opt_lst, t_1 <- t_1_lst}:Tparam_(v_I)*{}} {t_2_lst:Tresult_(v_I)*{}}} => (x, I') - -- if (v_I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(`%`_list(st_lst)), i))) - -- if (st_lst[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)))) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name(lift(id_opt)))*{id_opt <- id_opt_lst}, LABELS [], FIELDS [], TYPEDEFS []}) + prod{x : idx, I' : I, id_opt_lst : char?*, t_1_lst : valtype*, t_2_lst : valtype*, st_lst : subtype*, i : n} {{"("} {"type"} {x:Ttypeidx_(v_I)} {")"} {(t_1, ?(mk_name_name(lift(id_opt))))*{id_opt <- id_opt_lst, t_1 <- t_1_lst}:Tparam_(v_I)*{}} {t_2_lst:Tresult_(v_I)*{}}} => (x, I') + -- if (v_I.TYPEDEFS_I[$proj_uN_0(x).0] = ?(_DEF_deftype(REC_rectype(mk_list_list(st_lst)), i))) + -- if (st_lst[i] = SUB_subtype(?(FINAL_final), [], `FUNC%->%`_comptype(mk_list_resulttype(t_1_lst), mk_list_resulttype(t_2_lst)))) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(mk_name_name(lift(id_opt)))*{id_opt <- id_opt_lst}, LABELS [], FIELDS [], TYPEDEFS []}) -- Idctxt_ok: `|-%:OK`(I') ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec @@ -18657,9 +23719,9 @@ grammar Ttagtype_(v_I : I) : tagtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tglobaltype_(v_I : I) : globaltype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} t:Tvaltype_(v_I) => `%%`_globaltype(?(), t) + prod{t : valtype} t:Tvaltype_(v_I) => mk_globaltype_globaltype(?(), t) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{t : valtype} {{"("} {"mut"} {t:Tvaltype_(v_I)} {")"}} => `%%`_globaltype(?(MUT_mut), t) + prod{t : valtype} {{"("} {"mut"} {t:Tvaltype_(v_I)} {")"}} => mk_globaltype_globaltype(?(MUT_mut), t) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Tmemtype_(v_I : I) : memtype @@ -18669,20 +23731,20 @@ grammar Tmemtype_(v_I : I) : memtype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Ttabletype_(v_I : I) : tabletype ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{at : addrtype, lim : limits, rt : reftype} {{at:Taddrtype} {lim:Tlimits} {rt:Treftype_(v_I)}} => `%%%`_tabletype(at, lim, rt) + prod{at : addrtype, lim : limits, rt : reftype} {{at:Taddrtype} {lim:Tlimits} {rt:Treftype_(v_I)}} => mk_tabletype_tabletype(at, lim, rt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Texterntype_(v_I : I) : (externtype, idctxt) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{jt : tagtype, id_opt : char?} {{"("} {"tag"} {?(`%`_name(lift(id_opt))):Tid?{}} {jt:Ttagtype_(v_I)} {")"}} => (TAG_externtype(jt), {TYPES [], TAGS [?(`%`_name(lift(id_opt)))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{jt : tagtype, id_opt : char?} {{"("} {"tag"} {?(mk_name_name(lift(id_opt))):Tid?{}} {jt:Ttagtype_(v_I)} {")"}} => (TAG_externtype(jt), {TYPES [], TAGS [?(mk_name_name(lift(id_opt)))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{gt : globaltype, id_opt : char?} {{"("} {"global"} {?(`%`_name(lift(id_opt))):Tid?{}} {gt:Tglobaltype_(v_I)} {")"}} => (GLOBAL_externtype(gt), {TYPES [], TAGS [], GLOBALS [?(`%`_name(lift(id_opt)))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{gt : globaltype, id_opt : char?} {{"("} {"global"} {?(mk_name_name(lift(id_opt))):Tid?{}} {gt:Tglobaltype_(v_I)} {")"}} => (GLOBAL_externtype(gt), {TYPES [], TAGS [], GLOBALS [?(mk_name_name(lift(id_opt)))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{mt : memtype, id_opt : char?} {{"("} {"memory"} {?(`%`_name(lift(id_opt))):Tid?{}} {mt:Tmemtype_(v_I)} {")"}} => (MEM_externtype(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(`%`_name(lift(id_opt)))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{mt : memtype, id_opt : char?} {{"("} {"memory"} {?(mk_name_name(lift(id_opt))):Tid?{}} {mt:Tmemtype_(v_I)} {")"}} => (MEM_externtype(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(mk_name_name(lift(id_opt)))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{tt : tabletype, id_opt : char?} {{"("} {"table"} {?(`%`_name(lift(id_opt))):Tid?{}} {tt:Ttabletype_(v_I)} {")"}} => (TABLE_externtype(tt), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(`%`_name(lift(id_opt)))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{tt : tabletype, id_opt : char?} {{"("} {"table"} {?(mk_name_name(lift(id_opt))):Tid?{}} {tt:Ttabletype_(v_I)} {")"}} => (TABLE_externtype(tt), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(mk_name_name(lift(id_opt)))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec - prod{x : idx, id_opt : char?, I' : I} {{"("} {"func"} {?(`%`_name(lift(id_opt))):Tid?{}} {(x, I'):Ttypeuse_(v_I)} {")"}} => (FUNC_externtype(_IDX_typeuse(x)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id_opt)))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{x : idx, id_opt : char?, I' : I} {{"("} {"func"} {?(mk_name_name(lift(id_opt))):Tid?{}} {(x, I'):Ttypeuse_(v_I)} {")"}} => (FUNC_externtype(_IDX_typeuse(x)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(mk_name_name(lift(id_opt)))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tlabel_(v_I : I) : (name?, I) @@ -18701,7 +23763,7 @@ grammar Tblocktype_(v_I : I) : blocktype prod{t_opt : valtype?} t_opt:Tresult_(v_I)?{} => _RESULT_blocktype(t_opt) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, I' : I} (x, I'):Ttypeuse_(v_I) => _IDX_blocktype(x) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(mk_name_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tcatch_(v_I : I) : catch @@ -18725,22 +23787,22 @@ grammar Tlaneidx : laneidx ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Talign_(v_N : N) : u32 ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{v_n : n, v_m : m} {{"align="} {`%`_u64(v_m):Tu64}} => `%`_u32(v_n) + prod{v_n : n, v_m : m} {{"align="} {mk_uN_u64(v_m):Tu64}} => mk_uN_u32(v_n) -- if (v_m = (2 ^ v_n)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod eps => `%`_u32(v_N) + prod eps => mk_uN_u32(v_N) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Toffset : u64 ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{v_m : m} {{"offset="} {`%`_u64(v_m):Tu64}} => `%`_u64(v_m) + prod{v_m : m} {{"offset="} {mk_uN_u64(v_m):Tu64}} => mk_uN_u64(v_m) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod eps => `%`_u64(0) + prod eps => mk_uN_u64(0) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tmemarg_(v_N : N) : memarg ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{v_n : n, v_m : m} {{`%`_u32(v_n):Talign_(v_N)} {`%`_u64(v_m):Toffset}} => {ALIGN `%`_u32(v_n), OFFSET `%`_u64(v_m)} + prod{v_n : n, v_m : m} {{mk_uN_u32(v_n):Talign_(v_N)} {mk_uN_u64(v_m):Toffset}} => {ALIGN mk_uN_u32(v_n), OFFSET mk_uN_u64(v_m)} ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec grammar Tplaininstr_(v_I : I) : instr @@ -18772,7 +23834,7 @@ grammar Tplaininstr_(v_I : I) : instr prod{x : idx} {{"call_ref"} {x:Ttypeidx_(v_I)}} => CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"call_indirect"} {x:Ttableidx_(v_I)} {(y, I'):Ttypeuse_(v_I)}} => CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(mk_name_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "return" => RETURN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18781,37 +23843,37 @@ grammar Tplaininstr_(v_I : I) : instr prod{x : idx} {{"return_call_ref"} {x:Ttypeidx_(v_I)}} => RETURN_CALL_REF_instr(_IDX_typeuse(x)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, y : idx, I' : I} {{"return_call_indirect"} {x:Ttableidx_(v_I)} {(y, I'):Ttypeuse_(v_I)}} => RETURN_CALL_INDIRECT_instr(x, _IDX_typeuse(y)) - -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS ?(`%`_name([]))*{}, LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(mk_name_name([]))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx} {{"throw"} {x:Ttagidx_(v_I)}} => THROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "throw_ref" => THROW_REF_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.get"} {x:Tlocalidx_(v_I)}} => `LOCAL.GET`_instr(x) + prod{x : idx} {{"local.get"} {x:Tlocalidx_(v_I)}} => LOCAL_GET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.set"} {x:Tlocalidx_(v_I)}} => `LOCAL.SET`_instr(x) + prod{x : idx} {{"local.set"} {x:Tlocalidx_(v_I)}} => LOCAL_SET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"local.tee"} {x:Tlocalidx_(v_I)}} => `LOCAL.TEE`_instr(x) + prod{x : idx} {{"local.tee"} {x:Tlocalidx_(v_I)}} => LOCAL_TEE_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"global.get"} {x:Tglobalidx_(v_I)}} => `GLOBAL.GET`_instr(x) + prod{x : idx} {{"global.get"} {x:Tglobalidx_(v_I)}} => GLOBAL_GET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"global.set"} {x:Tglobalidx_(v_I)}} => `GLOBAL.SET`_instr(x) + prod{x : idx} {{"global.set"} {x:Tglobalidx_(v_I)}} => GLOBAL_SET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.get"} {x:Ttableidx_(v_I)}} => `TABLE.GET`_instr(x) + prod{x : idx} {{"table.get"} {x:Ttableidx_(v_I)}} => TABLE_GET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.set"} {x:Ttableidx_(v_I)}} => `TABLE.SET`_instr(x) + prod{x : idx} {{"table.set"} {x:Ttableidx_(v_I)}} => TABLE_SET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.size"} {x:Ttableidx_(v_I)}} => `TABLE.SIZE`_instr(x) + prod{x : idx} {{"table.size"} {x:Ttableidx_(v_I)}} => TABLE_SIZE_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.grow"} {x:Ttableidx_(v_I)}} => `TABLE.GROW`_instr(x) + prod{x : idx} {{"table.grow"} {x:Ttableidx_(v_I)}} => TABLE_GROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"table.fill"} {x:Ttableidx_(v_I)}} => `TABLE.FILL`_instr(x) + prod{x : idx} {{"table.fill"} {x:Ttableidx_(v_I)}} => TABLE_FILL_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"table.copy"} {x_1:Ttableidx_(v_I)} {x_2:Ttableidx_(v_I)}} => `TABLE.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{"table.copy"} {x_1:Ttableidx_(v_I)} {x_2:Ttableidx_(v_I)}} => TABLE_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"table.init"} {x:Ttableidx_(v_I)} {y:Telemidx_(v_I)}} => `TABLE.INIT`_instr(x, y) + prod{x : idx, y : idx} {{"table.init"} {x:Ttableidx_(v_I)} {y:Telemidx_(v_I)}} => TABLE_INIT_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"elem.drop"} {x:Telemidx_(v_I)}} => `ELEM.DROP`_instr(x) + prod{x : idx} {{"elem.drop"} {x:Telemidx_(v_I)}} => ELEM_DROP_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"i32.load"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => LOAD_instr(I32_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18821,59 +23883,59 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"f64.load"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => LOAD_instr(F64_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i32.load8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i32.load8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load16_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i32.load16_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.load16_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i32.load16_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(8), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load16_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load16_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load16_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(16), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load16_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(16), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load32_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), S_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load32_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(32), S_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.load32_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, `%_%`_loadop_Inn(`%`_sz(32), U_sx))), x, ao) + prod{x : idx, ao : memarg} {{"i64.load32_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => LOAD_instr(I64_numtype, ?(mk_loadop__0_loadop_(I64_Inn, mk_loadop_Inn_loadop_Inn(mk_sz_sz(32), U_sx))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"v128.load"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(16)}} => VLOAD_instr(V128_vectype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8x8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load8x8_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(8), 8, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8x8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(8), 8, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load8x8_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(8), 8, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16x4_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load16x4_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(16), 4, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16x4_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(16), 4, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load16x4_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(16), 4, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32x2_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, S_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load32x2_s"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(32), 2, S_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32x2_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(32), 2, U_sx)), x, ao) + prod{x : idx, ao : memarg} {{"v128.load32x2_u"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(mk_sz_sz(32), 2, U_sx)), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load8_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(8))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load8_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(8))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load16_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(16))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load16_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(16))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(32))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load32_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(32))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load64_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(64))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load64_splat"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(mk_sz_sz(64))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load32_zero"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(32))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load32_zero"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(32))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"v128.load64_zero"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(64))), x, ao) + prod{x : idx, ao : memarg} {{"v128.load64_zero"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(mk_sz_sz(64))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load8_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.load8_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(8), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load16_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.load16_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(16), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load32_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.load32_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(32), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.load64_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.load64_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VLOAD_LANE_instr(V128_vectype, mk_sz_sz(64), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"i32.store"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => STORE_instr(I32_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -18883,101 +23945,101 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"f64.store"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)}} => STORE_instr(F64_numtype, ?(), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.store8"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) + prod{x : idx, ao : memarg} {{"i32.store8"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i32.store16"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) + prod{x : idx, ao : memarg} {{"i32.store16"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(16)))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store8"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, ao) + prod{x : idx, ao : memarg} {{"i64.store8"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(8)))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store16"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(16)))), x, ao) + prod{x : idx, ao : memarg} {{"i64.store16"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(16)))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg} {{"i64.store32"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, `%`_storeop_Inn(`%`_sz(32)))), x, ao) + prod{x : idx, ao : memarg} {{"i64.store32"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)}} => STORE_instr(I64_numtype, ?(mk_storeop__0_storeop_(I64_Inn, mk_storeop_Inn_storeop_Inn(mk_sz_sz(32)))), x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{x : idx, ao : memarg} {{"v128.store"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(16)}} => VSTORE_instr(V128_vectype, x, ao) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store8_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(8), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.store8_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(1)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(8), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store16_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(16), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.store16_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(2)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(16), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store32_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(32), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.store32_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(4)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(32), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, ao : memarg, i : laneidx} {{"v128.store64_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, `%`_sz(64), x, ao, i) + prod{x : idx, ao : memarg, i : laneidx} {{"v128.store64_lane"} {x:Tmemidx_(v_I)} {ao:Tmemarg_(8)} {i:Tlaneidx}} => VSTORE_LANE_instr(V128_vectype, mk_sz_sz(64), x, ao, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.size"} {x:Tmemidx_(v_I)}} => `MEMORY.SIZE`_instr(x) + prod{x : idx} {{"memory.size"} {x:Tmemidx_(v_I)}} => MEMORY_SIZE_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.grow"} {x:Tmemidx_(v_I)}} => `MEMORY.GROW`_instr(x) + prod{x : idx} {{"memory.grow"} {x:Tmemidx_(v_I)}} => MEMORY_GROW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"memory.fill"} {x:Tmemidx_(v_I)}} => `MEMORY.FILL`_instr(x) + prod{x : idx} {{"memory.fill"} {x:Tmemidx_(v_I)}} => MEMORY_FILL_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"memory.copy"} {x_1:Tmemidx_(v_I)} {x_2:Tmemidx_(v_I)}} => `MEMORY.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{"memory.copy"} {x_1:Tmemidx_(v_I)} {x_2:Tmemidx_(v_I)}} => MEMORY_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"memory.init"} {x:Tmemidx_(v_I)} {y:Tdataidx_(v_I)}} => `MEMORY.INIT`_instr(x, y) + prod{x : idx, y : idx} {{"memory.init"} {x:Tmemidx_(v_I)} {y:Tdataidx_(v_I)}} => MEMORY_INIT_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"data.drop"} {x:Tdataidx_(v_I)}} => `DATA.DROP`_instr(x) + prod{x : idx} {{"data.drop"} {x:Tdataidx_(v_I)}} => DATA_DROP_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{ht : heaptype} {{"ref.null"} {ht:Theaptype_(v_I)}} => `REF.NULL`_instr(ht) + prod{ht : heaptype} {{"ref.null"} {ht:Theaptype_(v_I)}} => REF_NULL_instr(ht) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"ref.func"} {x:Tfuncidx_(v_I)}} => `REF.FUNC`_instr(x) + prod{x : idx} {{"ref.func"} {x:Tfuncidx_(v_I)}} => REF_FUNC_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.is_null" => `REF.IS_NULL`_instr + prod "ref.is_null" => REF_IS_NULL_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.as_non_null" => `REF.AS_NON_NULL`_instr + prod "ref.as_non_null" => REF_AS_NON_NULL_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.eq" => `REF.EQ`_instr + prod "ref.eq" => REF_EQ_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{rt : reftype} {{"ref.test"} {rt:Treftype_(v_I)}} => `REF.TEST`_instr(rt) + prod{rt : reftype} {{"ref.test"} {rt:Treftype_(v_I)}} => REF_TEST_instr(rt) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{rt : reftype} {{"ref.cast"} {rt:Treftype_(v_I)}} => `REF.CAST`_instr(rt) + prod{rt : reftype} {{"ref.cast"} {rt:Treftype_(v_I)}} => REF_CAST_instr(rt) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "ref.i31" => `REF.I31`_instr + prod "ref.i31" => REF_I31_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i31.get_s" => `I31.GET`_instr(S_sx) + prod "i31.get_s" => I31_GET_instr(S_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i31.get_u" => `I31.GET`_instr(U_sx) + prod "i31.get_u" => I31_GET_instr(U_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"struct.new"} {x:Ttypeidx_(v_I)}} => `STRUCT.NEW`_instr(x) + prod{x : idx} {{"struct.new"} {x:Ttypeidx_(v_I)}} => STRUCT_NEW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"struct.new_default"} {x:Ttypeidx_(v_I)}} => `STRUCT.NEW_DEFAULT`_instr(x) + prod{x : idx} {{"struct.new_default"} {x:Ttypeidx_(v_I)}} => STRUCT_NEW_DEFAULT_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => `STRUCT.GET`_instr(?(), x, i) + prod{x : idx, i : fieldidx} {{"struct.get"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => STRUCT_GET_instr(?(), x, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get_s"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => `STRUCT.GET`_instr(?(S_sx), x, i) + prod{x : idx, i : fieldidx} {{"struct.get_s"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => STRUCT_GET_instr(?(S_sx), x, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.get_u"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => `STRUCT.GET`_instr(?(U_sx), x, i) + prod{x : idx, i : fieldidx} {{"struct.get_u"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => STRUCT_GET_instr(?(U_sx), x, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, i : fieldidx} {{"struct.set"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => `STRUCT.SET`_instr(x, i) + prod{x : idx, i : fieldidx} {{"struct.set"} {x:Ttypeidx_(v_I)} {i:Tfieldidx__(v_I, x)}} => STRUCT_SET_instr(x, i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.new"} {x:Ttypeidx_(v_I)}} => `ARRAY.NEW`_instr(x) + prod{x : idx} {{"array.new"} {x:Ttypeidx_(v_I)}} => ARRAY_NEW_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.new_default"} {x:Ttypeidx_(v_I)}} => `ARRAY.NEW_DEFAULT`_instr(x) + prod{x : idx} {{"array.new_default"} {x:Ttypeidx_(v_I)}} => ARRAY_NEW_DEFAULT_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, v_n : n} {{"array.new_fixed"} {x:Ttypeidx_(v_I)} {`%`_u32(v_n):Tu32}} => `ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n)) + prod{x : idx, v_n : n} {{"array.new_fixed"} {x:Ttypeidx_(v_I)} {mk_uN_u32(v_n):Tu32}} => ARRAY_NEW_FIXED_instr(x, mk_uN_u32(v_n)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.new_data"} {x:Ttypeidx_(v_I)} {y:Tdataidx_(v_I)}} => `ARRAY.NEW_DATA`_instr(x, y) + prod{x : idx, y : idx} {{"array.new_data"} {x:Ttypeidx_(v_I)} {y:Tdataidx_(v_I)}} => ARRAY_NEW_DATA_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.new_elem"} {x:Ttypeidx_(v_I)} {y:Telemidx_(v_I)}} => `ARRAY.NEW_ELEM`_instr(x, y) + prod{x : idx, y : idx} {{"array.new_elem"} {x:Ttypeidx_(v_I)} {y:Telemidx_(v_I)}} => ARRAY_NEW_ELEM_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get"} {x:Ttypeidx_(v_I)}} => `ARRAY.GET`_instr(?(), x) + prod{x : idx} {{"array.get"} {x:Ttypeidx_(v_I)}} => ARRAY_GET_instr(?(), x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get_s"} {x:Ttypeidx_(v_I)}} => `ARRAY.GET`_instr(?(S_sx), x) + prod{x : idx} {{"array.get_s"} {x:Ttypeidx_(v_I)}} => ARRAY_GET_instr(?(S_sx), x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.get_u"} {x:Ttypeidx_(v_I)}} => `ARRAY.GET`_instr(?(U_sx), x) + prod{x : idx} {{"array.get_u"} {x:Ttypeidx_(v_I)}} => ARRAY_GET_instr(?(U_sx), x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.set"} {x:Ttypeidx_(v_I)}} => `ARRAY.SET`_instr(x) + prod{x : idx} {{"array.set"} {x:Ttypeidx_(v_I)}} => ARRAY_SET_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "array.len" => `ARRAY.LEN`_instr + prod "array.len" => ARRAY_LEN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx} {{"array.fill"} {x:Ttypeidx_(v_I)}} => `ARRAY.FILL`_instr(x) + prod{x : idx} {{"array.fill"} {x:Ttypeidx_(v_I)}} => ARRAY_FILL_instr(x) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x_1 : idx, x_2 : idx} {{"array.copy"} {x_1:Ttypeidx_(v_I)} {x_2:Ttypeidx_(v_I)}} => `ARRAY.COPY`_instr(x_1, x_2) + prod{x_1 : idx, x_2 : idx} {{"array.copy"} {x_1:Ttypeidx_(v_I)} {x_2:Ttypeidx_(v_I)}} => ARRAY_COPY_instr(x_1, x_2) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.init_data"} {x:Ttypeidx_(v_I)} {y:Tdataidx_(v_I)}} => `ARRAY.INIT_DATA`_instr(x, y) + prod{x : idx, y : idx} {{"array.init_data"} {x:Ttypeidx_(v_I)} {y:Tdataidx_(v_I)}} => ARRAY_INIT_DATA_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{x : idx, y : idx} {{"array.init_elem"} {x:Ttypeidx_(v_I)} {y:Telemidx_(v_I)}} => `ARRAY.INIT_ELEM`_instr(x, y) + prod{x : idx, y : idx} {{"array.init_elem"} {x:Ttypeidx_(v_I)} {y:Telemidx_(v_I)}} => ARRAY_INIT_ELEM_instr(x, y) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "any.convert_extern" => `ANY.CONVERT_EXTERN`_instr + prod "any.convert_extern" => ANY_CONVERT_EXTERN_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "extern.convert_any" => `EXTERN.CONVERT_ANY`_instr + prod "extern.convert_any" => EXTERN_CONVERT_ANY_instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{c : u32} {{"i32.const"} {c:Ti32}} => CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, c)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -19061,9 +24123,9 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "i32.popcnt" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, POPCNT_unop_Inn)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.extend8_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(8)))) + prod "i32.extend8_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(mk_sz_sz(8)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32.extend16_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(`%`_sz(16)))) + prod "i32.extend16_s" => UNOP_instr(I32_numtype, mk_unop__0_unop_(I32_Inn, EXTEND_unop_Inn(mk_sz_sz(16)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "i64.clz" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, CLZ_unop_Inn)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -19071,11 +24133,11 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "i64.popcnt" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, POPCNT_unop_Inn)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend8_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(8)))) + prod "i64.extend8_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(8)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend16_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(16)))) + prod "i64.extend16_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(16)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64.extend32_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(`%`_sz(32)))) + prod "i64.extend32_s" => UNOP_instr(I64_numtype, mk_unop__0_unop_(I64_Inn, EXTEND_unop_Inn(mk_sz_sz(32)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "f32.abs" => UNOP_instr(F32_numtype, mk_unop__1_unop_(F32_Fnn, ABS_unop_Fnn)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -19271,205 +24333,205 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod{c_lst : f64*} {{"v128.const"} {"f64x2"} {c_lst:Tf64^2{}}} => VCONST_instr(V128_vectype, $inv_ibytes_(128, $concat_(syntax byte, $fbytes_(64, c)*{c <- c_lst}))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i_lst : laneidx*} {{"i8x16.shuffle"} {i_lst:Tlaneidx^16{}}} => VSHUFFLE_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), i_lst) + prod{i_lst : laneidx*} {{"i8x16.shuffle"} {i_lst:Tlaneidx^16{}}} => VSHUFFLE_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), i_lst) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.swizzle" => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) + prod "i8x16.swizzle" => VSWIZZLOP_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vswizzlop__0_vswizzlop_(16, SWIZZLE_vswizzlop_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.relaxed_swizzle" => VSWIZZLOP_instr(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) + prod "i8x16.relaxed_swizzle" => VSWIZZLOP_instr(mk_bshape_bshape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vswizzlop__0_vswizzlop_(16, RELAXED_SWIZZLE_vswizzlop_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.splat" => VSPLAT_instr(`%X%`_shape(I8_lanetype, `%`_dim(16))) + prod "i8x16.splat" => VSPLAT_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.splat" => VSPLAT_instr(`%X%`_shape(I16_lanetype, `%`_dim(8))) + prod "i16x8.splat" => VSPLAT_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.splat" => VSPLAT_instr(`%X%`_shape(I32_lanetype, `%`_dim(4))) + prod "i32x4.splat" => VSPLAT_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.splat" => VSPLAT_instr(`%X%`_shape(I64_lanetype, `%`_dim(2))) + prod "i64x2.splat" => VSPLAT_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.splat" => VSPLAT_instr(`%X%`_shape(F32_lanetype, `%`_dim(4))) + prod "f32x4.splat" => VSPLAT_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.splat" => VSPLAT_instr(`%X%`_shape(F64_lanetype, `%`_dim(2))) + prod "f64x2.splat" => VSPLAT_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(S_sx), i) + prod{i : laneidx} {{"i8x16.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), ?(S_sx), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), ?(U_sx), i) + prod{i : laneidx} {{"i8x16.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), ?(U_sx), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(S_sx), i) + prod{i : laneidx} {{"i16x8.extract_lane_s"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), ?(S_sx), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), ?(U_sx), i) + prod{i : laneidx} {{"i16x8.extract_lane_u"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), ?(U_sx), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), ?(), i) + prod{i : laneidx} {{"i32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), ?(), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), ?(), i) + prod{i : laneidx} {{"i64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), ?(), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), ?(), i) + prod{i : laneidx} {{"f32x4.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), ?(), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), ?(), i) + prod{i : laneidx} {{"f64x2.extract_lane"} {i:Tlaneidx}} => VEXTRACT_LANE_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), ?(), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i8x16.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), i) + prod{i : laneidx} {{"i8x16.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i16x8.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), i) + prod{i : laneidx} {{"i16x8.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), i) + prod{i : laneidx} {{"i32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"i64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), i) + prod{i : laneidx} {{"i64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), i) + prod{i : laneidx} {{"f32x4.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod{i : laneidx} {{"f64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), i) + prod{i : laneidx} {{"f64x2.replace_lane"} {i:Tlaneidx}} => VREPLACE_LANE_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), i) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "v128.any_true" => VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.all_true" => VTESTOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) + prod "i8x16.all_true" => VTESTOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vtestop__0_vtestop_(I8_Jnn, 16, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.all_true" => VTESTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) + prod "i16x8.all_true" => VTESTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vtestop__0_vtestop_(I16_Jnn, 8, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.all_true" => VTESTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) + prod "i32x4.all_true" => VTESTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vtestop__0_vtestop_(I32_Jnn, 4, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.all_true" => VTESTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) + prod "i64x2.all_true" => VTESTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vtestop__0_vtestop_(I64_Jnn, 2, ALL_TRUE_vtestop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.eq" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) + prod "i8x16.eq" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ne" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) + prod "i8x16.ne" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.lt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) + prod "i8x16.lt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.lt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) + prod "i8x16.lt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.gt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) + prod "i8x16.gt_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.gt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) + prod "i8x16.gt_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.le_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) + prod "i8x16.le_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.le_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) + prod "i8x16.le_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ge_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) + prod "i8x16.ge_s" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.ge_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) + prod "i8x16.ge_u" => VRELOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vrelop__0_vrelop_(I8_Jnn, 16, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.eq" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) + prod "i16x8.eq" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ne" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) + prod "i16x8.ne" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.lt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) + prod "i16x8.lt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.lt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) + prod "i16x8.lt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.gt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) + prod "i16x8.gt_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.gt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) + prod "i16x8.gt_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.le_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) + prod "i16x8.le_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.le_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) + prod "i16x8.le_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ge_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) + prod "i16x8.ge_s" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.ge_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) + prod "i16x8.ge_u" => VRELOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vrelop__0_vrelop_(I16_Jnn, 8, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.eq" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) + prod "i32x4.eq" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ne" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) + prod "i32x4.ne" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.lt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) + prod "i32x4.lt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.lt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) + prod "i32x4.lt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.gt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) + prod "i32x4.gt_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.gt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) + prod "i32x4.gt_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GT_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.le_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) + prod "i32x4.le_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.le_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) + prod "i32x4.le_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, LE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ge_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) + prod "i32x4.ge_s" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.ge_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) + prod "i32x4.ge_u" => VRELOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vrelop__0_vrelop_(I32_Jnn, 4, GE_vrelop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.eq" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) + prod "i64x2.eq" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, EQ_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.ne" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) + prod "i64x2.ne" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, NE_vrelop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.lt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) + prod "i64x2.lt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.gt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) + prod "i64x2.gt_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GT_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.le_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) + prod "i64x2.le_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, LE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.ge_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) + prod "i64x2.ge_s" => VRELOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vrelop__0_vrelop_(I64_Jnn, 2, GE_vrelop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.eq" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) + prod "f32x4.eq" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, EQ_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ne" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) + prod "f32x4.ne" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, NE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.lt" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) + prod "f32x4.lt" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.gt" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) + prod "f32x4.gt" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.le" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) + prod "f32x4.le" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, LE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ge" => VRELOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) + prod "f32x4.ge" => VRELOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vrelop__1_vrelop_(F32_Fnn, 4, GE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.eq" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) + prod "f64x2.eq" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, EQ_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ne" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) + prod "f64x2.ne" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, NE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.lt" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) + prod "f64x2.lt" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.gt" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) + prod "f64x2.gt" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GT_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.le" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) + prod "f64x2.le" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, LE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ge" => VRELOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) + prod "f64x2.ge" => VRELOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vrelop__1_vrelop_(F64_Fnn, 2, GE_vrelop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "v128.not" => VVUNOP_instr(V128_vectype, NOT_vvunop) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.abs" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) + prod "i8x16.abs" => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.neg" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) + prod "i8x16.neg" => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.popcnt" => VUNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) + prod "i8x16.popcnt" => VUNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vunop__0_vunop_(I8_Jnn, 16, POPCNT_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.abs" => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) + prod "i16x8.abs" => VUNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.neg" => VUNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) + prod "i16x8.neg" => VUNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vunop__0_vunop_(I16_Jnn, 8, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.abs" => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) + prod "i32x4.abs" => VUNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.neg" => VUNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) + prod "i32x4.neg" => VUNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vunop__0_vunop_(I32_Jnn, 4, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.abs" => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) + prod "i64x2.abs" => VUNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, ABS_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.neg" => VUNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) + prod "i64x2.neg" => VUNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vunop__0_vunop_(I64_Jnn, 2, NEG_vunop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.abs" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) + prod "f32x4.abs" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, ABS_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.neg" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) + prod "f32x4.neg" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEG_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.sqrt" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) + prod "f32x4.sqrt" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, SQRT_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.ceil" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) + prod "f32x4.ceil" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, CEIL_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.floor" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) + prod "f32x4.floor" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, FLOOR_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.trunc" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) + prod "f32x4.trunc" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, TRUNC_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.nearest" => VUNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) + prod "f32x4.nearest" => VUNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vunop__1_vunop_(F32_Fnn, 4, NEAREST_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.abs" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) + prod "f64x2.abs" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, ABS_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.neg" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) + prod "f64x2.neg" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEG_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.sqrt" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) + prod "f64x2.sqrt" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, SQRT_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.ceil" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) + prod "f64x2.ceil" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, CEIL_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.floor" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) + prod "f64x2.floor" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, FLOOR_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.trunc" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) + prod "f64x2.trunc" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, TRUNC_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.nearest" => VUNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) + prod "f64x2.nearest" => VUNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vunop__1_vunop_(F64_Fnn, 2, NEAREST_vunop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "v128.and" => VVBINOP_instr(V128_vectype, AND_vvbinop) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec @@ -19479,263 +24541,263 @@ grammar Tplaininstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "v128.xor" => VVBINOP_instr(V128_vectype, XOR_vvbinop) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) + prod "i8x16.add" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) + prod "i8x16.add_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.add_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) + prod "i8x16.add_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, ADD_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) + prod "i8x16.sub" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) + prod "i8x16.sub_sat_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.sub_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) + prod "i8x16.sub_sat_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, SUB_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.min_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) + prod "i8x16.min_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.min_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) + prod "i8x16.min_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.max_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) + prod "i8x16.max_s" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.max_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) + prod "i8x16.max_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.avgr_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) + prod "i8x16.avgr_u" => VBINOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vbinop__0_vbinop_(I8_Jnn, 16, AVGRU_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) + prod "i16x8.add" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) + prod "i16x8.add_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.add_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) + prod "i16x8.add_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, ADD_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) + prod "i16x8.sub" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) + prod "i16x8.sub_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.sub_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) + prod "i16x8.sub_sat_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, SUB_SAT_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.mul" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) + prod "i16x8.mul" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.min_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) + prod "i16x8.min_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.min_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) + prod "i16x8.min_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.max_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) + prod "i16x8.max_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.max_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) + prod "i16x8.max_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.avgr_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) + prod "i16x8.avgr_u" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, AVGRU_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.q15mulr_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) + prod "i16x8.q15mulr_sat_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, Q15MULR_SATS_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_q15mulr_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) + prod "i16x8.relaxed_q15mulr_s" => VBINOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vbinop__0_vbinop_(I16_Jnn, 8, RELAXED_Q15MULRS_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.add" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) + prod "i32x4.add" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.sub" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) + prod "i32x4.sub" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.mul" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) + prod "i32x4.mul" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.min_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) + prod "i32x4.min_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.min_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) + prod "i32x4.min_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MIN_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.max_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) + prod "i32x4.max_s" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.max_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) + prod "i32x4.max_u" => VBINOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vbinop__0_vbinop_(I32_Jnn, 4, MAX_vbinop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.add" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) + prod "i64x2.add" => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, ADD_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.sub" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) + prod "i64x2.sub" => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, SUB_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.mul" => VBINOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) + prod "i64x2.mul" => VBINOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vbinop__0_vbinop_(I64_Jnn, 2, MUL_vbinop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.add" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) + prod "f32x4.add" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, ADD_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.sub" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) + prod "f32x4.sub" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, SUB_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.mul" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) + prod "f32x4.mul" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MUL_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.div" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) + prod "f32x4.div" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, DIV_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.min" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) + prod "f32x4.min" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.max" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) + prod "f32x4.max" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.pmin" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) + prod "f32x4.pmin" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.pmax" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) + prod "f32x4.pmax" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, PMAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_min" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) + prod "f32x4.relaxed_min" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_max" => VBINOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) + prod "f32x4.relaxed_max" => VBINOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vbinop__1_vbinop_(F32_Fnn, 4, RELAXED_MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.add" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) + prod "f64x2.add" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, ADD_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.sub" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) + prod "f64x2.sub" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, SUB_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.mul" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) + prod "f64x2.mul" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MUL_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.div" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) + prod "f64x2.div" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, DIV_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.min" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) + prod "f64x2.min" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.max" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) + prod "f64x2.max" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.pmin" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) + prod "f64x2.pmin" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.pmax" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) + prod "f64x2.pmax" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, PMAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_min" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) + prod "f64x2.relaxed_min" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MIN_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_max" => VBINOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) + prod "f64x2.relaxed_max" => VBINOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vbinop__1_vbinop_(F64_Fnn, 2, RELAXED_MAX_vbinop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec prod "v128.bitselect" => VVTERNOP_instr(V128_vectype, BITSELECT_vvternop) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) + prod "i8x16.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vternop__0_vternop_(I8_Jnn, 16, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) + prod "i16x8.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vternop__0_vternop_(I16_Jnn, 8, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) + prod "i32x4.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vternop__0_vternop_(I32_Jnn, 4, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) + prod "i64x2.relaxed_laneselect" => VTERNOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), mk_vternop__0_vternop_(I64_Jnn, 2, RELAXED_LANESELECT_vternop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) + prod "f32x4.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_MADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) + prod "f32x4.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vternop__1_vternop_(F32_Fnn, 4, RELAXED_NMADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) + prod "f64x2.relaxed_madd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_MADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) + prod "f64x2.relaxed_nmadd" => VTERNOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vternop__1_vternop_(F64_Fnn, 2, RELAXED_NMADD_vternop_Fnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) + prod "i8x16.shl" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) + prod "i8x16.shr_s" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) + prod "i8x16.shr_u" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vshiftop__0_vshiftop_(I8_Jnn, 16, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) + prod "i16x8.shl" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) + prod "i16x8.shr_s" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) + prod "i16x8.shr_u" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vshiftop__0_vshiftop_(I16_Jnn, 8, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) + prod "i32x4.shl" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) + prod "i32x4.shr_s" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) + prod "i32x4.shr_u" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vshiftop__0_vshiftop_(I32_Jnn, 4, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shl" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) + prod "i64x2.shl" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHL_vshiftop_Jnn_M)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shr_s" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) + prod "i64x2.shr_s" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.shr_u" => VSHIFTOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) + prod "i64x2.shr_u" => VSHIFTOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_vshiftop__0_vshiftop_(I64_Jnn, 2, SHR_vshiftop_Jnn_M(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16)))) + prod "i8x16.bitmask" => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8)))) + prod "i16x8.bitmask" => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4)))) + prod "i32x4.bitmask" => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.bitmask" => VBITMASK_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2)))) + prod "i64x2.bitmask" => VBITMASK_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.narrow_i16x8_s" => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), S_sx) + prod "i8x16.narrow_i16x8_s" => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), S_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i8x16.narrow_i16x8_u" => VNARROW_instr(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), U_sx) + prod "i8x16.narrow_i16x8_u" => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), U_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.narrow_i32x4_s" => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), S_sx) + prod "i16x8.narrow_i32x4_s" => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), S_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.narrow_i32x4_u" => VNARROW_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), U_sx) + prod "i16x8.narrow_i32x4_u" => VNARROW_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), U_sx) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_low_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i16x8.extend_low_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_low_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i16x8.extend_low_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_high_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i16x8.extend_high_i8x16_s" => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extend_high_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, `%`_dim(8)), `%X%`_shape(I8_lanetype, `%`_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i16x8.extend_high_i8x16_u" => VCVTOP_instr(`%X%`_shape(I16_lanetype, mk_dim_dim(8)), `%X%`_shape(I8_lanetype, mk_dim_dim(16)), mk_vcvtop___0_vcvtop__(I8_Jnn, 16, I16_Jnn, 8, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_low_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i32x4.extend_low_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_low_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i32x4.extend_low_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_high_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i32x4.extend_high_i16x8_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extend_high_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(I16_lanetype, `%`_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i32x4.extend_high_i16x8_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(I16_lanetype, mk_dim_dim(8)), mk_vcvtop___0_vcvtop__(I16_Jnn, 8, I32_Jnn, 4, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) + prod "i32x4.trunc_sat_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) + prod "i32x4.trunc_sat_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) + prod "i32x4.trunc_sat_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.trunc_sat_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) + prod "i32x4.trunc_sat_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, TRUNC_SAT_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) + prod "i32x4.relaxed_trunc_f32x4_s" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?()))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) + prod "i32x4.relaxed_trunc_f32x4_u" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___2_vcvtop__(F32_Fnn, 4, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?()))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) + prod "i32x4.relaxed_trunc_f64x2_s_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(S_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_trunc_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) + prod "i32x4.relaxed_trunc_f64x2_u_zero" => VCVTOP_instr(`%X%`_shape(I32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___2_vcvtop__(F64_Fnn, 2, I32_Jnn, 4, RELAXED_TRUNC_vcvtop__Fnn_1_M_1_Jnn_2_M_2(U_sx, ?(ZERO_zero)))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i64x2.extend_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i64x2.extend_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_high_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i64x2.extend_high_i32x4_s" => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extend_high_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i64x2.extend_high_i32x4_u" => VCVTOP_instr(`%X%`_shape(I64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___0_vcvtop__(I32_Jnn, 4, I64_Jnn, 2, EXTEND_vcvtop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.demote_f64x2_zero" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(F64_lanetype, `%`_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) + prod "f32x4.demote_f64x2_zero" => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(F64_lanetype, mk_dim_dim(2)), mk_vcvtop___3_vcvtop__(F64_Fnn, 2, F32_Fnn, 4, DEMOTE_vcvtop__Fnn_1_M_1_Fnn_2_M_2(ZERO_zero))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.convert_i32x4_s" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) + prod "f32x4.convert_i32x4_s" => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f32x4.convert_i32x4_u" => VCVTOP_instr(`%X%`_shape(F32_lanetype, `%`_dim(4)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) + prod "f32x4.convert_i32x4_u" => VCVTOP_instr(`%X%`_shape(F32_lanetype, mk_dim_dim(4)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F32_Fnn, 4, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(), U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.promote_low_f32x4" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(F32_lanetype, `%`_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) + prod "f64x2.promote_low_f32x4" => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(F32_lanetype, mk_dim_dim(4)), mk_vcvtop___3_vcvtop__(F32_Fnn, 4, F64_Fnn, 2, PROMOTELOW_vcvtop__Fnn_1_M_1_Fnn_2_M_2)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.convert_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) + prod "f64x2.convert_low_i32x4_s" => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "f64x2.convert_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(F64_lanetype, `%`_dim(2)), `%X%`_shape(I32_lanetype, `%`_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) + prod "f64x2.convert_low_i32x4_u" => VCVTOP_instr(`%X%`_shape(F64_lanetype, mk_dim_dim(2)), `%X%`_shape(I32_lanetype, mk_dim_dim(4)), mk_vcvtop___1_vcvtop__(I32_Jnn, 4, F64_Fnn, 2, CONVERT_vcvtop__Jnn_1_M_1_Fnn_2_M_2(?(LOW_half), U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extadd_pairwise_i8x16_s" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + prod "i16x8.extadd_pairwise_i8x16_s" => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extadd_pairwise_i8x16_u" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) + prod "i16x8.extadd_pairwise_i8x16_u" => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextunop___0_vextunop__(I8_Jnn, 16, I16_Jnn, 8, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extadd_pairwise_i16x8_s" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) + prod "i32x4.extadd_pairwise_i16x8_s" => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extadd_pairwise_i16x8_u" => VEXTUNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) + prod "i32x4.extadd_pairwise_i16x8_u" => VEXTUNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextunop___0_vextunop__(I16_Jnn, 8, I32_Jnn, 4, EXTADD_PAIRWISE_vextunop__Jnn_1_M_1_Jnn_2_M_2(U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_low_i8x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i16x8.extmul_low_i8x16_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_low_i8x16_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i16x8.extmul_low_i8x16_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_high_i8x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i16x8.extmul_high_i8x16_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.extmul_high_i8x16_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i16x8.extmul_high_i8x16_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i16x8.relaxed_dot_i8x16_i7x16_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), `%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + prod "i16x8.relaxed_dot_i8x16_i7x16_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_ishape_ishape(`%X%`_shape(I8_lanetype, mk_dim_dim(16))), mk_vextbinop___0_vextbinop__(I8_Jnn, 16, I16_Jnn, 8, RELAXED_DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_low_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i32x4.extmul_low_i16x8_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_low_i16x8_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i32x4.extmul_low_i16x8_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_high_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i32x4.extmul_high_i16x8_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.extmul_high_i16x8_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i32x4.extmul_high_i16x8_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.dot_i16x8_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) + prod "i32x4.dot_i16x8_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextbinop___0_vextbinop__(I16_Jnn, 8, I32_Jnn, 4, DOTS_vextbinop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_low_i32x4_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) + prod "i64x2.extmul_low_i32x4_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_low_i32x4_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) + prod "i64x2.extmul_low_i32x4_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(LOW_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_high_i32x4_s" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) + prod "i64x2.extmul_high_i32x4_s" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, S_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i64x2.extmul_high_i32x4_u" => VEXTBINOP_instr(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(2))), `%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) + prod "i64x2.extmul_high_i32x4_u" => VEXTBINOP_instr(mk_ishape_ishape(`%X%`_shape(I64_lanetype, mk_dim_dim(2))), mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_vextbinop___0_vextbinop__(I32_Jnn, 4, I64_Jnn, 2, EXTMUL_vextbinop__Jnn_1_M_1_Jnn_2_M_2(HIGH_half, U_sx))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec - prod "i32x4.relaxed_dot_i8x16_i7x16_add_s" => VEXTTERNOP_instr(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(4))), `%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) + prod "i32x4.relaxed_dot_i8x16_i7x16_add_s" => VEXTTERNOP_instr(mk_ishape_ishape(`%X%`_shape(I32_lanetype, mk_dim_dim(4))), mk_ishape_ishape(`%X%`_shape(I16_lanetype, mk_dim_dim(8))), mk_vextternop___0_vextternop__(I16_Jnn, 8, I32_Jnn, 4, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec rec { @@ -19757,16 +24819,16 @@ grammar Tinstrs_(v_I : I) : instr* ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:88.1-90.65 grammar Tblockinstr_(v_I : I) : instr ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:63.5-67.35 - prod{bt : blocktype, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"block"} {(?(`%`_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_lst:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'_opt))):Tid?{}}} => BLOCK_instr(bt, in_lst) + prod{bt : blocktype, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"block"} {(?(mk_name_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_lst:Tinstrs_(I')} {"end"} {?(mk_name_name(lift(id'_opt))):Tid?{}}} => BLOCK_instr(bt, in_lst) -- if ((id'_opt = ?()) \/ (id'_opt = id_opt)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:68.5-72.35 - prod{bt : blocktype, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"loop"} {(?(`%`_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_lst:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'_opt))):Tid?{}}} => LOOP_instr(bt, in_lst) + prod{bt : blocktype, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"loop"} {(?(mk_name_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_lst:Tinstrs_(I')} {"end"} {?(mk_name_name(lift(id'_opt))):Tid?{}}} => LOOP_instr(bt, in_lst) -- if ((id'_opt = ?()) \/ (id'_opt = id_opt)) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:73.5-79.71 - prod{bt : blocktype, in_1_lst : instr*, in_2_lst : instr*, id_opt : char?, I' : I, id_1_opt : char?, id_2_opt : char?} {{"if"} {(?(`%`_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_1_lst:Tinstrs_(I')} {"else"} {?(`%`_name(lift(id_1_opt))):Tid?{}} {in_2_lst:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id_2_opt))):Tid?{}}} => `IF%%ELSE%`_instr(bt, in_1_lst, in_2_lst) + prod{bt : blocktype, in_1_lst : instr*, in_2_lst : instr*, id_opt : char?, I' : I, id_1_opt : char?, id_2_opt : char?} {{"if"} {(?(mk_name_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {in_1_lst:Tinstrs_(I')} {"else"} {?(mk_name_name(lift(id_1_opt))):Tid?{}} {in_2_lst:Tinstrs_(I')} {"end"} {?(mk_name_name(lift(id_2_opt))):Tid?{}}} => `IF%%ELSE%`_instr(bt, in_1_lst, in_2_lst) -- if (((id_1_opt = ?()) \/ (id_1_opt = id_opt)) /\ ((id_2_opt = ?()) \/ (id_2_opt = id_opt))) ;; ../../../../specification/wasm-3.0/6.3-text.instructions.spectec:80.5-85.35 - prod{bt : blocktype, c_lst : catch*, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"try_table"} {(?(`%`_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {c_lst:Tcatch_(v_I)*{}} {in_lst:Tinstrs_(I')} {"end"} {?(`%`_name(lift(id'_opt))):Tid?{}}} => TRY_TABLE_instr(bt, `%`_list(c_lst), in_lst) + prod{bt : blocktype, c_lst : catch*, in_lst : instr*, id_opt : char?, I' : I, id'_opt : char?} {{"try_table"} {(?(mk_name_name(lift(id_opt))), I'):Tlabel_(v_I)} {bt:Tblocktype_(v_I)} {c_lst:Tcatch_(v_I)*{}} {in_lst:Tinstrs_(I')} {"end"} {?(mk_name_name(lift(id'_opt))):Tid?{}}} => TRY_TABLE_instr(bt, mk_list_list(c_lst), in_lst) -- if ((id'_opt = ?()) \/ (id'_opt = id_opt)) } @@ -19779,40 +24841,41 @@ grammar Texpr_(v_I : I) : expr grammar Ttype_(v_I : I) : (type, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec prod{qt : rectype, I' : I, I'' : I, v_n : n, st_lst : subtype*} (qt, I'):Trectype_(v_I) => (TYPE_type(qt), I' +++ I'') - -- if (qt = REC_rectype(`%`_list(st_lst))) + -- if (qt = REC_rectype(mk_list_list(st_lst))) -- if (I'' = {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS ?(_DEF_deftype(qt, i))^(i (TAG_tag(jt), {TYPES [], TAGS [?(`%`_name(lift(id_opt)))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{jt : tagtype, id_opt : char?} {{"("} {"tag"} {?(mk_name_name(lift(id_opt))):Tid?{}} {jt:Ttagtype_(v_I)} {")"}} => (TAG_tag(jt), {TYPES [], TAGS [?(mk_name_name(lift(id_opt)))], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tglobal_(v_I : I) : (global, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{gt : globaltype, e : expr, id_opt : char?} {{"("} {"global"} {?(`%`_name(lift(id_opt))):Tid?{}} {gt:Tglobaltype_(v_I)} {e:Texpr_(v_I)} {")"}} => (GLOBAL_global(gt, e), {TYPES [], TAGS [], GLOBALS [?(`%`_name(lift(id_opt)))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{gt : globaltype, e : expr, id_opt : char?} {{"("} {"global"} {?(mk_name_name(lift(id_opt))):Tid?{}} {gt:Tglobaltype_(v_I)} {e:Texpr_(v_I)} {")"}} => (GLOBAL_global(gt, e), {TYPES [], TAGS [], GLOBALS [?(mk_name_name(lift(id_opt)))], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tmem_(v_I : I) : (mem, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{mt : memtype, id_opt : char?} {{"("} {"memory"} {?(`%`_name(lift(id_opt))):Tid?{}} {mt:Tmemtype_(v_I)} {")"}} => (MEMORY_mem(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(`%`_name(lift(id_opt)))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{mt : memtype, id_opt : char?} {{"("} {"memory"} {?(mk_name_name(lift(id_opt))):Tid?{}} {mt:Tmemtype_(v_I)} {")"}} => (MEMORY_mem(mt), {TYPES [], TAGS [], GLOBALS [], MEMS [?(mk_name_name(lift(id_opt)))], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Ttable_(v_I : I) : (table, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{tt : tabletype, e : expr, id_opt : char?} {{"("} {"table"} {?(`%`_name(lift(id_opt))):Tid?{}} {tt:Ttabletype_(v_I)} {e:Texpr_(v_I)} {")"}} => (TABLE_table(tt, e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(`%`_name(lift(id_opt)))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{tt : tabletype, e : expr, id_opt : char?} {{"("} {"table"} {?(mk_name_name(lift(id_opt))):Tid?{}} {tt:Ttabletype_(v_I)} {e:Texpr_(v_I)} {")"}} => (TABLE_table(tt, e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [?(mk_name_name(lift(id_opt)))], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tlocal_(v_I : I) : (local*, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{t : valtype, id_opt : char?} {{"("} {"local"} {?(`%`_name(lift(id_opt))):Tid?{}} {t:Tvaltype_(v_I)} {")"}} => ([LOCAL_local(t)], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(`%`_name(lift(id_opt)))], LABELS [], FIELDS [], TYPEDEFS []}) + prod{t : valtype, id_opt : char?} {{"("} {"local"} {?(mk_name_name(lift(id_opt))):Tid?{}} {t:Tvaltype_(v_I)} {")"}} => ([LOCAL_local(t)], {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [?(mk_name_name(lift(id_opt)))], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tfunc_(v_I : I) : (func, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{x : idx, loc_lst_lst : local**, e : expr, id_opt : char?, I_1 : I, I_2_lst : I*, I' : I} {{"("} {"func"} {?(`%`_name(lift(id_opt))):Tid?{}} {(x, I_1):Ttypeuse_(v_I)} {(loc_lst, I_2):Tlocal_(v_I)*{I_2 <- I_2_lst, loc_lst <- loc_lst_lst}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc_lst_lst), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(`%`_name(lift(id_opt)))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) - -- if (I' = v_I +++ I_1 +++ $concat_idctxt(I_2_lst)) + prod{x : idx, loc_lst_lst : local**, e : expr, id_opt : char?, I_1 : I, I_2_lst : I*, I' : I, var_0 : I} {{"("} {"func"} {?(mk_name_name(lift(id_opt))):Tid?{}} {(x, I_1):Ttypeuse_(v_I)} {(loc_lst, I_2):Tlocal_(v_I)*{I_2 <- I_2_lst, loc_lst <- loc_lst_lst}} {e:Texpr_(I')} {")"}} => (FUNC_func(x, $concat_(syntax local, loc_lst_lst), e), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [?(mk_name_name(lift(id_opt)))], DATAS [], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + -- if (I' = v_I +++ I_1 +++ var_0) -- Idctxt_ok: `|-%:OK`(I') + -- fun_concat_idctxt: `%%`(I_2_lst, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdatastring : byte* @@ -19832,9 +24895,9 @@ grammar Toffset_(v_I : I) : expr ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdata_(v_I : I) : (data, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{b_lst : byte*, id_opt : char?} {{"("} {"data"} {?(`%`_name(lift(id_opt))):Tid?{}} {b_lst:Tdatastring} {")"}} => (DATA_data(b_lst, PASSIVE_datamode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(`%`_name(lift(id_opt)))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{b_lst : byte*, id_opt : char?} {{"("} {"data"} {?(mk_name_name(lift(id_opt))):Tid?{}} {b_lst:Tdatastring} {")"}} => (DATA_data(b_lst, PASSIVE_datamode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(mk_name_name(lift(id_opt)))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{b_lst : byte*, x : idx, e : expr, id_opt : char?} {{"("} {"data"} {?(`%`_name(lift(id_opt))):Tid?{}} {x:Tmemuse_(v_I)} {e:Toffset_(v_I)} {b_lst:Tdatastring} {")"}} => (DATA_data(b_lst, ACTIVE_datamode(x, e)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(`%`_name(lift(id_opt)))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{b_lst : byte*, x : idx, e : expr, id_opt : char?} {{"("} {"data"} {?(mk_name_name(lift(id_opt))):Tid?{}} {x:Tmemuse_(v_I)} {e:Toffset_(v_I)} {b_lst:Tdatastring} {")"}} => (DATA_data(b_lst, ACTIVE_datamode(x, e)), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [?(mk_name_name(lift(id_opt)))], ELEMS [], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Telemexpr_(v_I : I) : expr @@ -19854,11 +24917,11 @@ grammar Ttableuse_(v_I : I) : tableidx ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Telem_(v_I : I) : (elem, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, e_lst : expr*, id_opt : char?} {{"("} {"elem"} {?(`%`_name(lift(id_opt))):Tid?{}} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, PASSIVE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{rt : reftype, e_lst : expr*, id_opt : char?} {{"("} {"elem"} {?(mk_name_name(lift(id_opt))):Tid?{}} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, PASSIVE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(mk_name_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, e_lst : expr*, x : idx, e' : expr, id_opt : char?} {{"("} {"elem"} {?(`%`_name(lift(id_opt))):Tid?{}} {x:Ttableuse_(v_I)} {e':Toffset_(v_I)} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, ACTIVE_elemmode(x, e')), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{rt : reftype, e_lst : expr*, x : idx, e' : expr, id_opt : char?} {{"("} {"elem"} {?(mk_name_name(lift(id_opt))):Tid?{}} {x:Ttableuse_(v_I)} {e':Toffset_(v_I)} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, ACTIVE_elemmode(x, e')), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(mk_name_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{rt : reftype, e_lst : expr*, id_opt : char?} {{"("} {"elem"} {?(`%`_name(lift(id_opt))):Tid?{}} {"declare"} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, DECLARE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(`%`_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) + prod{rt : reftype, e_lst : expr*, id_opt : char?} {{"("} {"elem"} {?(mk_name_name(lift(id_opt))):Tid?{}} {"declare"} {(rt, e_lst):Telemlist_(v_I)} {")"}} => (ELEM_elem(rt, e_lst, DECLARE_elemmode), {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [?(mk_name_name(lift(id_opt)))], LOCALS [], LABELS [], FIELDS [], TYPEDEFS []}) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tstart_(v_I : I) : (start, idctxt) @@ -19973,21 +25036,34 @@ grammar Tdecl_(v_I : I) : (decl, idctxt) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tmodule : module ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - prod{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, I_lst : I*, decl_lst : decl*, I' : I} {{"("} {"module"} {Tid?{}} {(v_decl, v_I)*{v_I <- I_lst, v_decl <- decl_lst}:Tdecl_(I')*{}} {")"}} => MODULE_module(`%`_list(type_lst), `%`_list(import_lst), `%`_list(tag_lst), `%`_list(global_lst), `%`_list(mem_lst), `%`_list(table_lst), `%`_list(func_lst), `%`_list(data_lst), `%`_list(elem_lst), start_opt, `%`_list(export_lst)) - -- if (I' = $concat_idctxt(I_lst)) + prod{type_lst : type*, import_lst : import*, tag_lst : tag*, global_lst : global*, mem_lst : mem*, table_lst : table*, func_lst : func*, data_lst : data*, elem_lst : elem*, start_opt : start?, export_lst : export*, I_lst : I*, decl_lst : decl*, I' : I, var_12 : bool, var_11 : export*, var_10 : start*, var_9 : elem*, var_8 : data*, var_7 : func*, var_6 : table*, var_5 : mem*, var_4 : global*, var_3 : tag*, var_2 : import*, var_1 : type*, var_0 : idctxt} {{"("} {"module"} {Tid?{}} {(v_decl, v_I)*{v_I <- I_lst, v_decl <- decl_lst}:Tdecl_(I')*{}} {")"}} => MODULE_module(mk_list_list(type_lst), mk_list_list(import_lst), mk_list_list(tag_lst), mk_list_list(global_lst), mk_list_list(mem_lst), mk_list_list(table_lst), mk_list_list(func_lst), mk_list_list(data_lst), mk_list_list(elem_lst), start_opt, mk_list_list(export_lst)) + -- if (I' = var_0) -- Idctxt_ok: `|-%:OK`(I') - -- if (type_lst = $typesd(decl_lst)) - -- if (import_lst = $importsd(decl_lst)) - -- if (tag_lst = $tagsd(decl_lst)) - -- if (global_lst = $globalsd(decl_lst)) - -- if (mem_lst = $memsd(decl_lst)) - -- if (table_lst = $tablesd(decl_lst)) - -- if (func_lst = $funcsd(decl_lst)) - -- if (data_lst = $datasd(decl_lst)) - -- if (elem_lst = $elemsd(decl_lst)) - -- if (lift(start_opt) = $startsd(decl_lst)) - -- if (export_lst = $exportsd(decl_lst)) - -- if $ordered(decl_lst) + -- if (type_lst = var_1) + -- if (import_lst = var_2) + -- if (tag_lst = var_3) + -- if (global_lst = var_4) + -- if (mem_lst = var_5) + -- if (table_lst = var_6) + -- if (func_lst = var_7) + -- if (data_lst = var_8) + -- if (elem_lst = var_9) + -- if (lift(start_opt) = var_10) + -- if (export_lst = var_11) + -- if var_12 + -- fun_ordered: `%%`(decl_lst, var_12) + -- fun_exportsd: `%%`(decl_lst, var_11) + -- fun_startsd: `%%`(decl_lst, var_10) + -- fun_elemsd: `%%`(decl_lst, var_9) + -- fun_datasd: `%%`(decl_lst, var_8) + -- fun_funcsd: `%%`(decl_lst, var_7) + -- fun_tablesd: `%%`(decl_lst, var_6) + -- fun_memsd: `%%`(decl_lst, var_5) + -- fun_globalsd: `%%`(decl_lst, var_4) + -- fun_tagsd: `%%`(decl_lst, var_3) + -- fun_importsd: `%%`(decl_lst, var_2) + -- fun_typesd: `%%`(decl_lst, var_1) + -- fun_concat_idctxt: `%%`(I_lst, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec grammar Tdecldots_(v_I : I) : (decl, idctxt)* @@ -19995,7 +25071,7 @@ grammar Tdecldots_(v_I : I) : (decl, idctxt)* prod{`` : (decl, idctxt)} [``]:Tdecl_(v_I)*{} => [``] ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec -grammar Bvar(syntax X) : () +grammar Bvar(syntax r_X) : () ;; ../../../../specification/wasm-3.0/X.4-notation.binary.spectec prod 0x00 => ((), ()).1 @@ -20014,7 +25090,7 @@ grammar Bsymsplit : () prod{`` : ()} ``:Bvar(syntax B) => (``, ()).1 ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec -grammar Tvar(syntax X) : () +grammar Tvar(syntax r_X) : () ;; ../../../../specification/wasm-3.0/X.5-notation.text.spectec prod 0x00 => ((), ()).1 diff --git a/spectec/test-middlend/test.spectec b/spectec/test-middlend/test.spectec index 933b224916..82d8a46852 100644 --- a/spectec/test-middlend/test.spectec +++ b/spectec/test-middlend/test.spectec @@ -33,4 +33,27 @@ def $t_totalize3(n) = $($t_totalize(n) + $t_totalize2($(n + 10))) ;; def $t_totalize3(n) = $($t_totalize(n) + $t_totalize2($t_totalize(n))) ;; ;; def $t_totalize4(nat) : nat hint(partial) -;; def $t_totalize4(n) = $t_totalize($t_totalize(n)) \ No newline at end of file +;; def $t_totalize4(n) = $t_totalize($t_totalize(n)) + +;; +;; Pattern Simp testing +;; + +syntax A = B nat + +def $t_patsimp(nat, nat) : nat +def $t_patsimp(n, n) = n +def $t_patsimp(n, m) = $(n + m) + +def $t_patsimp2(nat, nat, A) : nat +def $t_patsimp2(n, n, B n) = n +def $t_patsimp2(n, m, B m) = $(n + m) +def $t_patsimp2(n, m, B k) = $(n + m + k) + +def $find(nat, nat*) : bool +def $find(n, eps) = false +def $find(n, n n'*) = true +def $find(n, n_1 n'*) = $find(n, n'*) + +def $len(int*) : nat +def $len(i^n) = n \ No newline at end of file diff --git a/spectec/test-middlend/test.spectec.exp b/spectec/test-middlend/test.spectec.exp index dfda9d09a7..eeebecef8b 100644 --- a/spectec/test-middlend/test.spectec.exp +++ b/spectec/test-middlend/test.spectec.exp @@ -30,6 +30,44 @@ def $t_totalize3(nat : nat) : nat ;; test.spectec def $t_totalize3{n : nat}(n) = ($t_totalize(n) + $t_totalize2((n + 10))) +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation... == Running pass ite... @@ -62,6 +100,44 @@ def $t_totalize3(nat : nat) : nat ;; test.spectec def $t_totalize3{n : nat}(n) = ($t_totalize(n) + $t_totalize2((n + 10))) +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass ite... == Running pass let-intro-mech... @@ -94,6 +170,44 @@ def $t_totalize3(nat : nat) : nat ;; test.spectec def $t_totalize3{n : nat}(n) = ($t_totalize(n) + $t_totalize2((n + 10))) +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass let-intro-mech... == Running pass typefamily-removal... @@ -126,6 +240,44 @@ def $t_totalize3(nat : nat) : nat ;; test.spectec def $t_totalize3{n : nat}(n) = ($t_totalize(n) + $t_totalize2((n + 10))) +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass typefamily-removal... == Running pass remove-indexed-types... @@ -158,6 +310,44 @@ def $t_totalize3(nat : nat) : nat ;; test.spectec def $t_totalize3{n : nat}(n) = ($t_totalize(n) + $t_totalize2((n + 10))) +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass remove-indexed-types... == Running pass totalize... @@ -192,6 +382,44 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass totalize... == Running pass else... @@ -226,6 +454,44 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass else... == Running pass else-simplification... @@ -260,6 +526,44 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass else-simplification... == Running pass uncase-removal... @@ -294,8 +598,46 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'*{n' <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'*{n' <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i^n{i <- `i*`}) = n + == IL Validation after pass uncase-removal... -== Running pass sideconditions... +== Running pass sub-expansion... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -305,8 +647,6 @@ relation TestNestedIter: `%|-%`(nat***, nat**) ;; test.spectec rule _{`n***` : nat***, `m**` : nat**}: `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) - -- if (|`m**`| = |`n***`|) - -- (if (|`m*`| = |`n**`|))+{`m*` <- `m**`, `n**` <- `n***`} -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec @@ -330,8 +670,46 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} -== IL Validation after pass sideconditions... -== Running pass sub-expansion... +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat}(n, n) = n + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat}(n, n, B_A(n)) = n + ;; test.spectec + def $t_patsimp2{n : nat, m : nat}(n, m, B_A(m)) = (n + m) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*}(n, [n] ++ n'#1*{n'#1 <- `n'*`}) = true + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i#1^n{i#1 <- `i*`}) = n + +== IL Validation after pass sub-expansion... +== Running pass pattern-simp... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -341,8 +719,6 @@ relation TestNestedIter: `%|-%`(nat***, nat**) ;; test.spectec rule _{`n***` : nat***, `m**` : nat**}: `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) - -- if (|`m**`| = |`n***`|) - -- (if (|`m*`| = |`n**`|))+{`m*` <- `m**`, `n**` <- `n***`} -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec @@ -366,7 +742,51 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} -== IL Validation after pass sub-expansion... +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat, n_0 : nat}(n, n_0) = n + -- if (n = n_0) + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat, n_1 : nat, n_0 : nat}(n, n_0, B_A(n_1)) = n + -- if (n = n_1) + -- if (n = n_0) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, m_0 : nat}(n, m, B_A(m_0)) = (n + m) + -- if (m = m_0) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*, n_0 : nat}(n, [n_0] ++ n'#1*{n'#1 <- `n'*`}) = true + -- if (n = n_0) + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i#1*{i#1 <- `i*`}) = n + -- if (n = |`i*`|) + +== IL Validation after pass pattern-simp... == Running pass sub... ;; test.spectec @@ -377,8 +797,6 @@ relation TestNestedIter: `%|-%`(nat***, nat**) ;; test.spectec rule _{`n***` : nat***, `m**` : nat**}: `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) - -- if (|`m**`| = |`n***`|) - -- (if (|`m*`| = |`n**`|))+{`m*` <- `m**`, `n**` <- `n***`} -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec @@ -402,8 +820,145 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +def $t_patsimp(nat : nat, nat : nat) : nat + ;; test.spectec + def $t_patsimp{n : nat, n_0 : nat}(n, n_0) = n + -- if (n = n_0) + ;; test.spectec + def $t_patsimp{n : nat, m : nat}(n, m) = (n + m) + +;; test.spectec +def $t_patsimp2(nat : nat, nat : nat, A : A) : nat + ;; test.spectec + def $t_patsimp2{n : nat, n_1 : nat, n_0 : nat}(n, n_0, B_A(n_1)) = n + -- if (n = n_1) + -- if (n = n_0) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, m_0 : nat}(n, m, B_A(m_0)) = (n + m) + -- if (m = m_0) + ;; test.spectec + def $t_patsimp2{n : nat, m : nat, k : nat}(n, m, B_A(k)) = ((n + m) + k) + +;; test.spectec +rec { + +;; test.spectec:53.1-53.28 +def $find(nat : nat, nat*) : bool + ;; test.spectec:54.1-54.26 + def $find{n : nat}(n, []) = false + ;; test.spectec:55.1-55.27 + def $find{n : nat, `n'*` : nat*, n_0 : nat}(n, [n_0] ++ n'#1*{n'#1 <- `n'*`}) = true + -- if (n = n_0) + ;; test.spectec:56.1-56.38 + def $find{n : nat, n_1 : nat, `n'*` : nat*}(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}) = $find(n, n'*{n' <- `n'*`}) +} + +;; test.spectec +def $len(int*) : nat + ;; test.spectec + def $len{n : nat, `i*` : int*}(i#1*{i#1 <- `i*`}) = n + -- if (n = |`i*`|) + == IL Validation after pass sub... -== Running pass alias-demut... +== Running pass definition-to-relation... + +;; test.spectec +relation HasSize: `%|-%`(nat, nat) + +;; test.spectec +relation TestNestedIter: `%|-%`(nat***, nat**) + ;; test.spectec + rule _{`n***` : nat***, `m**` : nat**}: + `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) + -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} + +;; test.spectec +def $t_totalize(nat : nat) : nat? + ;; test.spectec + def $t_totalize(3) = ?(5) + ;; test.spectec + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise + +;; test.spectec +def $t_totalize2(nat : nat) : nat? + ;; test.spectec + def $t_totalize2(1) = ?(2) + ;; test.spectec + def $t_totalize2{n : nat}(n) = $t_totalize(n) + +;; test.spectec +def $t_totalize3(nat : nat) : nat? + ;; test.spectec + def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} + +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +relation fun_t_patsimp: `%%%`(nat, nat, nat) + ;; test.spectec + rule fun_t_patsimp_case_0{n : nat, n_0 : nat}: + `%%%`(n, n_0, n) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp_case_1{n : nat, m : nat}: + `%%%`(n, m, (n + m)) + +;; test.spectec +relation fun_t_patsimp2: `%%%%`(nat, nat, A, nat) + ;; test.spectec + rule fun_t_patsimp2_case_0{n : nat, n_1 : nat, n_0 : nat}: + `%%%%`(n, n_0, B_A(n_1), n) + -- if (n = n_1) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp2_case_1{n : nat, m : nat, m_0 : nat}: + `%%%%`(n, m, B_A(m_0), (n + m)) + -- if (m = m_0) + + ;; test.spectec + rule fun_t_patsimp2_case_2{n : nat, m : nat, k : nat}: + `%%%%`(n, m, B_A(k), ((n + m) + k)) + +;; test.spectec +rec { + +;; test.spectec:53.6-53.11 +relation fun_find: `%%%`(nat, nat*, bool) + ;; test.spectec:53.6-53.11 + rule fun_find_case_0{n : nat}: + `%%%`(n, [], false) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_1{n : nat, `n'*` : nat*, n_0 : nat}: + `%%%`(n, [n_0] ++ n'#1*{n'#1 <- `n'*`}, true) + -- if (n = n_0) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_2{n : nat, n_1 : nat, `n'*` : nat*, var_0 : bool}: + `%%%`(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}, var_0) + -- fun_find: `%%%`(n, n'*{n' <- `n'*`}, var_0) +} + +;; test.spectec +relation fun_len: `%%`(int*, nat) + ;; test.spectec + rule fun_len_case_0{n : nat, `i*` : int*}: + `%%`(i#1*{i#1 <- `i*`}, n) + -- if (n = |`i*`|) + +== IL Validation after pass definition-to-relation... +== Running pass sideconditions... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -413,9 +968,104 @@ relation TestNestedIter: `%|-%`(nat***, nat**) ;; test.spectec rule _{`n***` : nat***, `m**` : nat**}: `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) + -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} -- if (|`m**`| = |`n***`|) -- (if (|`m*`| = |`n**`|))+{`m*` <- `m**`, `n**` <- `n***`} + +;; test.spectec +def $t_totalize(nat : nat) : nat? + ;; test.spectec + def $t_totalize(3) = ?(5) + ;; test.spectec + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise + +;; test.spectec +def $t_totalize2(nat : nat) : nat? + ;; test.spectec + def $t_totalize2(1) = ?(2) + ;; test.spectec + def $t_totalize2{n : nat}(n) = $t_totalize(n) + +;; test.spectec +def $t_totalize3(nat : nat) : nat? + ;; test.spectec + def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} + +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +relation fun_t_patsimp: `%%%`(nat, nat, nat) + ;; test.spectec + rule fun_t_patsimp_case_0{n : nat, n_0 : nat}: + `%%%`(n, n_0, n) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp_case_1{n : nat, m : nat}: + `%%%`(n, m, (n + m)) + +;; test.spectec +relation fun_t_patsimp2: `%%%%`(nat, nat, A, nat) + ;; test.spectec + rule fun_t_patsimp2_case_0{n : nat, n_1 : nat, n_0 : nat}: + `%%%%`(n, n_0, B_A(n_1), n) + -- if (n = n_1) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp2_case_1{n : nat, m : nat, m_0 : nat}: + `%%%%`(n, m, B_A(m_0), (n + m)) + -- if (m = m_0) + + ;; test.spectec + rule fun_t_patsimp2_case_2{n : nat, m : nat, k : nat}: + `%%%%`(n, m, B_A(k), ((n + m) + k)) + +;; test.spectec +rec { + +;; test.spectec:53.6-53.11 +relation fun_find: `%%%`(nat, nat*, bool) + ;; test.spectec:53.6-53.11 + rule fun_find_case_0{n : nat}: + `%%%`(n, [], false) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_1{n : nat, `n'*` : nat*, n_0 : nat}: + `%%%`(n, [n_0] ++ n'#1*{n'#1 <- `n'*`}, true) + -- if (n = n_0) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_2{n : nat, n_1 : nat, `n'*` : nat*, var_0 : bool}: + `%%%`(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}, var_0) + -- fun_find: `%%%`(n, n'*{n' <- `n'*`}, var_0) +} + +;; test.spectec +relation fun_len: `%%`(int*, nat) + ;; test.spectec + rule fun_len_case_0{n : nat, `i*` : int*}: + `%%`(i#1*{i#1 <- `i*`}, n) + -- if (n = |`i*`|) + +== IL Validation after pass sideconditions... +== Running pass alias-demut... + +;; test.spectec +relation HasSize: `%|-%`(nat, nat) + +;; test.spectec +relation TestNestedIter: `%|-%`(nat***, nat**) + ;; test.spectec + rule _{`n***` : nat***, `m**` : nat**}: + `%|-%`(n*{n <- `n*`}*{`n*` <- `n**`}+{`n**` <- `n***`}, m*{m <- `m*`}+{`m*` <- `m**`}) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} + -- if (|`m**`| = |`n***`|) + -- (if (|`m*`| = |`n**`|))+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec def $t_totalize(nat : nat) : nat? @@ -438,6 +1088,65 @@ def $t_totalize3(nat : nat) : nat? ;; test.spectec def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +relation fun_t_patsimp: `%%%`(nat, nat, nat) + ;; test.spectec + rule fun_t_patsimp_case_0{n : nat, n_0 : nat}: + `%%%`(n, n_0, n) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp_case_1{n : nat, m : nat}: + `%%%`(n, m, (n + m)) + +;; test.spectec +relation fun_t_patsimp2: `%%%%`(nat, nat, A, nat) + ;; test.spectec + rule fun_t_patsimp2_case_0{n : nat, n_1 : nat, n_0 : nat}: + `%%%%`(n, n_0, B_A(n_1), n) + -- if (n = n_1) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp2_case_1{n : nat, m : nat, m_0 : nat}: + `%%%%`(n, m, B_A(m_0), (n + m)) + -- if (m = m_0) + + ;; test.spectec + rule fun_t_patsimp2_case_2{n : nat, m : nat, k : nat}: + `%%%%`(n, m, B_A(k), ((n + m) + k)) + +;; test.spectec +rec { + +;; test.spectec:53.6-53.11 +relation fun_find: `%%%`(nat, nat*, bool) + ;; test.spectec:53.6-53.11 + rule fun_find_case_0{n : nat}: + `%%%`(n, [], false) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_1{n : nat, `n'*` : nat*, n_0 : nat}: + `%%%`(n, [n_0] ++ n'#1*{n'#1 <- `n'*`}, true) + -- if (n = n_0) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_2{n : nat, n_1 : nat, `n'*` : nat*, var_0 : bool}: + `%%%`(n, [n_1] ++ n'#2*{n'#2 <- `n'*`}, var_0) + -- fun_find: `%%%`(n, n'*{n' <- `n'*`}, var_0) +} + +;; test.spectec +relation fun_len: `%%`(int*, nat) + ;; test.spectec + rule fun_len_case_0{n : nat, `i*` : int*}: + `%%`(i#1*{i#1 <- `i*`}, n) + -- if (n = |`i*`|) + == IL Validation after pass alias-demut... == Running pass improve-ids... @@ -449,9 +1158,9 @@ relation TestNestedIter: `%|-%`(nat***, nat**) ;; test.spectec rule mk_TestNestedIter{n_lst_lst_lst : nat***, m_lst_lst : nat**}: `%|-%`(n_lst_lst_lst, m_lst_lst) + -- (if (|n_lst| = m))*{m <- m_lst, n_lst <- n_lst_lst}+{m_lst <- m_lst_lst, n_lst_lst <- n_lst_lst_lst} -- if (|m_lst_lst| = |n_lst_lst_lst|) -- (if (|m_lst| = |n_lst_lst|))+{m_lst <- m_lst_lst, n_lst_lst <- n_lst_lst_lst} - -- (if (|n_lst| = m))*{m <- m_lst, n_lst <- n_lst_lst}+{m_lst <- m_lst_lst, n_lst_lst <- n_lst_lst_lst} ;; test.spectec def $t_totalize(nat : nat) : nat? @@ -472,7 +1181,66 @@ def $t_totalize2(nat : nat) : nat? ;; test.spectec def $t_totalize3(nat : nat) : nat? ;; test.spectec - def $t_totalize3{n : nat}(n) = (iter_val#2 + iter_val#1)?{iter_val#2 <- $t_totalize(n), iter_val#1 <- $t_totalize2((n + 10))} + def $t_totalize3{n : nat}(n) = (iter_val_2 + iter_val_1)?{iter_val_2 <- $t_totalize(n), iter_val_1 <- $t_totalize2((n + 10))} + +;; test.spectec +syntax A = + | B(nat) + +;; test.spectec +relation fun_t_patsimp: `%%%`(nat, nat, nat) + ;; test.spectec + rule fun_t_patsimp_case_0{n : nat, n_0 : nat}: + `%%%`(n, n_0, n) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp_case_1{n : nat, m : nat}: + `%%%`(n, m, (n + m)) + +;; test.spectec +relation fun_t_patsimp2: `%%%%`(nat, nat, A, nat) + ;; test.spectec + rule fun_t_patsimp2_case_0{n : nat, n_1 : nat, n_0 : nat}: + `%%%%`(n, n_0, B_A(n_1), n) + -- if (n = n_1) + -- if (n = n_0) + + ;; test.spectec + rule fun_t_patsimp2_case_1{n : nat, m : nat, m_0 : nat}: + `%%%%`(n, m, B_A(m_0), (n + m)) + -- if (m = m_0) + + ;; test.spectec + rule fun_t_patsimp2_case_2{n : nat, m : nat, k : nat}: + `%%%%`(n, m, B_A(k), ((n + m) + k)) + +;; test.spectec +rec { + +;; test.spectec:53.6-53.11 +relation fun_find: `%%%`(nat, nat*, bool) + ;; test.spectec:53.6-53.11 + rule fun_find_case_0{n : nat}: + `%%%`(n, [], false) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_1{n : nat, n'_lst : nat*, n_0 : nat}: + `%%%`(n, [n_0] ++ n'_lst, true) + -- if (n = n_0) + + ;; test.spectec:53.6-53.11 + rule fun_find_case_2{n : nat, n_1 : nat, n'_lst : nat*, var_0 : bool}: + `%%%`(n, [n_1] ++ n'_lst, var_0) + -- fun_find: `%%%`(n, n'_lst, var_0) +} + +;; test.spectec +relation fun_len: `%%`(int*, nat) + ;; test.spectec + rule fun_len_case_0{n : nat, i_lst : int*}: + `%%`(i_lst, n) + -- if (n = |i_lst|) == IL Validation after pass improve-ids... == Complete.